1.hello1代码分析

hello.java

package javaeetutorial.hello1;

import javax.enterprise.context.RequestScoped;#导入了一个java包,注解类型为RequestScoped((1)指定bean是请求范围的 (2) 请求范围处于活动状态   (3)请求上下文被销毁)
import javax.inject.Named;#导入了一个java包,注解类型为Named(常用于命名注解javax.inject.Name并 javax.enterprise.context.RequestScoped使用请求范围将类标识为托管bean。范围定义应用程序数据如何保持和共享)

@Named
@RequestScoped

#使用两个注解
public class Hello {#定义一个公共类

private String name;#一个私有字符串name

public Hello() { #定义自身类对象
    }

public String getName() {定义对象getName,返回name
        return name;
    }

public void setName(String user_name) {#将setNaame设置为返回值对象,把user_name赋值给this.name
        this.name = user_name;
    }
}

hello.1.web.xml

<?xml version="1.0" encoding="UTF-8"?>#xml版本号和编码
<web-app version="3.1" #web-app版本号
         xmlns="http://xmlns.jcp.org/xml/ns/javaee" #表示web.xml命名空间
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" #类url
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd">#指定web.xml约束文件xsd所在位置
    <context-param>#表明应用范围内的初始化参数
        <param-name>javax.faces.PROJECT_STAGE</param-name>#将参数名为faces的包导入project_stage
        <param-value>Development</param-value>#参数值
    </context-param>
    <servlet>#在向servlet或JSP页面制定初始化参数或定制URL时,必须首先命名servlet或JSP页面。
        <servlet-name>Faces Servlet</servlet-name>#servlet命名
        <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>#指定servlet类包
        <load-on-startup>1</load-on-startup>#启动负载为1
    </servlet>
    <servlet-mapping>#更改缺省url
        <servlet-name>Faces Servlet</servlet-name>
        <url-pattern>*.xhtml</url-pattern>#指定url参数类型
    </servlet-mapping>
    <session-config>#指定缺省超时值
        <session-timeout>#会话超时为30
            30
        </session-timeout>
    </session-config>
    <welcome-file-list>#指示服务器在收到引用一个目录名而不是文件名的URL时,使用的文件
        <welcome-file>index.xhtml</welcome-file>#应用index.xhtml文件
    </welcome-file-list>
</web-app>

2.hello2代码分析

Responseservlet.java:
package javaeetutorial.hello2;  #软件包名为javaeetutorial.hello2

import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

  #导入io 和 serverlet相关的各类包
@WebServlet("/response")

  #注解WebServerlet 为response
public class ResponseServlet extends HttpServlet {

  #定义类ReponseServerlet从HttpServerlet拓展而来

@Override

  #注解Override
public void doGet(HttpServletRequest request,

  #定义对象doGet ,定义HttpServerletRequest 为request

HttpServletResponse response)

  #定义HttpServerResponse 为response
throws ServletException, IOException {

  #抛出异常
try (PrintWriter out = response.getWriter()) {

  #将response的getWeite方法赋值给PrintWrite的out,response的getWrite方法来自于HttpServletResponse接口方法
String username = request.getParameter("username");

  #将request的getParameter方法获得的username赋值给字符串username,requset来自于HttpServerletRequest接口方法
if (username != null && username.length() > 0) {

  #当username字符串不为空且username的长度大于0时
out.println("<h2>Hello, " + username + "!</h2>");

  #调用out的println打印Hello,和字符串
}
}
}

@Override
public String getServletInfo() {
return "The Response servlet says hello.";

  #定义字符串getServerletinfo,返回内容

}
}

GreetingServlet.java:

package javaeetutorial.hello2;  

  #包名hello2

import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

  #导入各类需要的资源包

@WebServlet("/greeting")  

  #注解名greeting
public class GreetingServlet extends HttpServlet {

  #拓展类GreetingServlet从HttpServlet接口

@Override

  #注解Override
public void doGet(HttpServletRequest request,
HttpServletResponse response)

  #同上定义对象 HttpServletRequest名为request,HttpServletResponse名为response
throws ServletException, IOException {

  #抛出异常

response.setContentType("text/html");

  #定义文本类型为text,html
response.setBufferSize(8192);

  #定义缓冲池大小8192
try (PrintWriter out = response.getWriter()) {
out.println("<html lang=\"en\">"
+ "<head><title>Servlet Hello</title></head>");

// then write the data of the response
out.println("<body bgcolor=\"#ffffff\">"
+ "<img src=\"resources/images/duke.waving.gif\" "
+ "alt=\"Duke waving his hand\">"
+ "<form method=\"get\">"
+ "<h2>Hello, my name is Duke. What's yours?</h2>"
+ "<input title=\"My name is: \" type=\"text\" "
+ "name=\"username\" size=\"25\"/>"
+ "<p></p>"
+ "<input type=\"submit\" value=\"Submit\"/>"
+ "<input type=\"reset\" value=\"Reset\"/>"
+ "</form>");

  #以上是打印网页页面相关内容

String username = request.getParameter("username");
if (username != null && username.length() > 0) {
RequestDispatcher dispatcher =
getServletContext().getRequestDispatcher("/response");
  #将response响应赋给dispatcher分发调度
if (dispatcher != null) {
dispatcher.include(request, response);
}

  #当匹配到处理请求响应的处理服务时,就返回请求和response.java的响应内容结果
}
out.println("</body></html>");
}
}

@Override
public String getServletInfo() {
return "The Hello servlet says hello.";

  #在页面返回响应的文字

}
}

引用:https://www.cnblogs.com/lijianxuan/p/10606299.html

hello1和hello2代码分析的更多相关文章

  1. hello1 hello2 代码分析

    1.hello1代码分析 hello.java package javaeetutorial.hello1; import javax.enterprise.context.RequestScoped ...

  2. hello1与hello2的代码分析

    1.hello1代码分析 hello.java package javaeetutorial.hello1; import javax.enterprise.context.RequestScoped ...

  3. Android代码分析工具lint学习

    1 lint简介 1.1 概述 lint是随Android SDK自带的一个静态代码分析工具.它用来对Android工程的源文件进行检查,找出在正确性.安全.性能.可使用性.可访问性及国际化等方面可能 ...

  4. pmd静态代码分析

    在正式进入测试之前,进行一定的静态代码分析及code review对代码质量及系统提高是有帮助的,以上为数据证明 Pmd 它是一个基于静态规则集的Java源码分析器,它可以识别出潜在的如下问题:– 可 ...

  5. [Asp.net 5] DependencyInjection项目代码分析-目录

    微软DI文章系列如下所示: [Asp.net 5] DependencyInjection项目代码分析 [Asp.net 5] DependencyInjection项目代码分析2-Autofac [ ...

  6. [Asp.net 5] DependencyInjection项目代码分析4-微软的实现(5)(IEnumerable<>补充)

    Asp.net 5的依赖注入注入系列可以参考链接: [Asp.net 5] DependencyInjection项目代码分析-目录 我们在之前讲微软的实现时,对于OpenIEnumerableSer ...

  7. 完整全面的Java资源库(包括构建、操作、代码分析、编译器、数据库、社区等等)

    构建 这里搜集了用来构建应用程序的工具. Apache Maven:Maven使用声明进行构建并进行依赖管理,偏向于使用约定而不是配置进行构建.Maven优于Apache Ant.后者采用了一种过程化 ...

  8. STM32启动代码分析 IAR 比较好

    stm32启动代码分析 (2012-06-12 09:43:31) 转载▼     最近开始使用ST的stm32w108芯片(也是一款zigbee芯片).开始看他的启动代码看的晕晕呼呼呼的. 还好在c ...

  9. 常用 Java 静态代码分析工具的分析与比较

    常用 Java 静态代码分析工具的分析与比较 简介: 本文首先介绍了静态代码分析的基 本概念及主要技术,随后分别介绍了现有 4 种主流 Java 静态代码分析工具 (Checkstyle,FindBu ...

随机推荐

  1. 【转】子类会调用父类的@PostConstruct方法

    如果一个类用@Service或@Component,那么只需要用@PostConstruct修饰某个方法,该方法能在类实例化的过程中自动执行,相当于类的构造函数.同时,具备了构造函数不具备的功能. @ ...

  2. go语言中使用defer、panic、recover处理异常

    go语言中的异常处理,没有try...catch等,而是使用defer.panic.recover来处理异常. 1.首先,panic 是用来表示非常严重的不可恢复的错误的.在Go语言中这是一个内置函数 ...

  3. SQLAlchemy+Flask-RESTful使用(四)

    前言 顺利出到4啦,其实学习过程中发现了不少错误,不过有些实在是没啥代表性. 最近买了两本小程序和安卓方面的书,其实从初中开始,想搞编程的目的就是写些安卓软件. 现在看来不太可能了.拿来当当兴趣爱好还 ...

  4. webpack是什么

    1,打包工具 模块打包 2.前端工程师 ,必不可少工具webpack作用 1.打包 (多个文件,打包成一个文件) 2.转化(less,sass,ts) 需要核心 技术 loader 3优化(SPA越来 ...

  5. maven的配置-2019-4-13

    一.Maven的优点 1.  依赖管理 jar 包管理 2.一键构建 (编译-----测试------打包-----安装-----部署 ) 什么是项目构建? 指的是项目从编译-----测试------ ...

  6. shell echo/read/printf/流程控制章节笔记

    // echo read printf 流程控制 命令 1.read 命令从标准输入中读取一行,并把输入行的每个字段的值指定给 shell 变量 read hello 输入xxx echo $hell ...

  7. 链表详解(C语言)

    链表是一种常见的基础数据结构,结构体指针在这里得到了充分的利用. 链表可以动态的进行存储分配,也就是说,链表是一个功能极为强大的数组,他可以在节点中定义多种数据类型,还可以根据需要随意增添,删除,插入 ...

  8. Django组件-Forms组件

    Django的Forms组件主要有以下几大功能: 页面初始化,生成HTML标签 校验用户数据(显示错误信息) HTML Form提交保留上次提交数据 一.小试牛刀 1.定义Form类 from dja ...

  9. sql 语句中count()有条件的时候为什么要加上or null

    参考:https://blog.csdn.net/qq_32719287/article/details/79513164 1.sql 语句中count()有条件的时候为什么要加上or null. 如 ...

  10. SQL @@Rowcount

    @@Rowcount主要是返回上次sql语句所影响的数据行数 SELECT * FROM dbo.Region AS R SELECT @@rowcount SELECT @@rowcount --我 ...