Web---创建Servlet的3种方式、简单的用户注册功能
说明:
创建Servlet的方式,在上篇博客中,已经用了方式1(实现Servlet接口),接下来本节讲的是另外2种方式。
上篇博客地址:http://blog.csdn.net/qq_26525215/article/details/51942252
简单的用户注册功能(我们设置了所以权限都是开放的),可以实现:
1、用户注册。
2、查询所有用户
3、删除某个用户
创建Servlet的方式二:继承 GenericServlet
SecondServlet.java:
package cn.hncu.servlet.day2;
import java.io.IOException;
import javax.servlet.GenericServlet;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
//以继承GenericServlet 的方式 写 servlet
public class SecondServlet extends GenericServlet{
//一个小知识点!!!
//适配器模式的一个知识点:适配器中的init(ServletConfig config)中帮我们把它当中的config对象赋值 且调用一个空参的init()。
//我们以后应该覆盖空参的init()。因为如果覆盖了这个带参数的,那么就无法实现为它的config对象赋值,由此导致其中使用config对象(this.)的方法会出错。
////其实这种方法(调用 一个空参的init()且 该参数方法中什么也没做 )也程序员之间的一种交流方式,告诉我们要覆盖空参的方法,这样它在帮我们做完事情会调用我们的覆盖方法
// @Override
// public void init(ServletConfig config) throws ServletException {
// System.out.println(config);//这里不会出现问题,父类:init(ServletConfig config)中有这一句:this.config = config;
// String charset = config.getInitParameter("charset");
// System.out.println(charset);
// System.out.println("init..."+this);
// }
@Override
public void init() throws ServletException {
System.out.println("init...."+this);
}
@Override
public void service(ServletRequest request, ServletResponse response)
throws ServletException, IOException {
//String charset = this.getInitParameter("charset");
//如果本例写了init(ServletConfig config)方法,覆盖了父类的init(ServletConfig config)方法,这句会出异常
//System.out.println(charset);
String charset = this.getInitParameter("charset");
System.out.println(charset);
request.setCharacterEncoding("utf-8");
String name = request.getParameter("name");
String pwd = request.getParameter("pwd");
System.out.println("name:"+name+",pwd:"+pwd);
}
}
index.jsp:
<hr/>
<h1>下面是本章节博客的内容</h1>
<h2>演示servlet技术---第二种创建Servlet的方式(继承GenericServlet)</h2>
<form action="/myServletDemo/second" method="post">
访问SecondServlet<br/>
姓名:<input type="text" name="name"/> <br/>
密码:<input type="password" name="pwd"/><br/>
<input type="submit" value="提交" />
</form>
web.xml:
<!-- 下面的是今天这节博客的 -->
<servlet>
<servlet-name>SecondServlet</servlet-name>
<servlet-class>cn.hncu.servlet.day2.SecondServlet</servlet-class>
<init-param>
<param-name>charset</param-name>
<param-value>utf-8</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>SecondServlet</servlet-name>
<url-pattern>/second</url-pattern>
</servlet-mapping>
演示结果:
填写好姓名,密码后点击提交:
再看后台:
创建Servlet的方式三:继承HttpServlet
index.jsp:
<h2>演示servlet技术---第三种Servlet的方式(继承HttpServlet)</h2>
<form action="/myServletDemo/third" method="post">
访问ThirdServlet<br/>
姓名:<input type="text" name="name"><br/>
密码:<input type="password" name="pwd"><br/>
<input type="submit" value="提交" />
</form>
web.xml:
<servlet>
<servlet-name>ThirdServlet</servlet-name>
<servlet-class>cn.hncu.servlet.day2.ThirdServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>ThirdServlet</servlet-name>
<url-pattern>/third</url-pattern>
</servlet-mapping>
ThirdServlet.java:
package cn.hncu.servlet.day2;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
//注意:采用继承HttpServlet的方式写servlet,doGet和doPost这2个方法通常都要覆盖
//否则如果doGet方法没覆盖,有get请求时就会出现405错误,不覆盖doPost方法同理
public class ThirdServlet extends HttpServlet{
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
System.out.println("get...");
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
System.out.println("post");
}
}
覆盖doGet和doPost这2个方法的说明:
注意:采用继承HttpServlet的方式写servlet,doGet和doPost这2个方法通常都要覆盖
否则如果doGet方法没覆盖,有get请求时就会出现405错误,不覆盖doPost方法同理.
产生这个的原因是:
我们来看底层代码:
这是一个常量:
public static final int SC_METHOD_NOT_ALLOWED = 405;
因为HttpServlet继承GenericServlet,GenericServlet implements Servlet。所以,当客户端访问的时候,最先找的是:父类的servlet
也就是:service(ServletRequest req, ServletResponse res)
这个方法继续调用:service(request, response);
再通过这个方法调用doGet()或doPost()或其他方法。
如果我们没覆盖doGet()或doPost()。
我们用的是http1.1协议,会调用resp.sendError(HttpServletResponse.SC_METHOD_NOT_ALLOWED, msg);于是出现了405错误!
演示结果:
、
我们将表单提交的方式定义成post提交了的。默认是get
简单的用户注册功能:
首先,我们需要一个xml,用来存储用户的注册信息;
我们在项目的src文件夹下建立了一个user.xml文件。
user.xml:
我们只写了xml的头,和需要的一个根元素
<?xml version="1.0" encoding="UTF-8"?>
<users>
</users>
写一个公共类工厂:Dom4jFactory
大家共用访问同一个document~。
(单例)
Dom4jFactory.java
package cn.hncu.factory;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import org.dom4j.Document;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
public class Dom4jFactory {
private static Document dom = null;
private static String path;
//静态块!只会运行一次!特点是在类加载的时候就执行
static{
try{
SAXReader sax = new SAXReader();
// 学习一下服务器下的资源路径加载方式(因为我们的资源已经从MyEclipse中发布到Tomcat服务器中了,所以跟原来纯Java项目不一样了)
// 利用当前类找到它的类加载器,然后通过该类加载器再去获得资源路径
path = Dom4jFactory.class.getClassLoader().getResource("users.xml").getPath();
//getClassLoader()返回:加载此对象所表示的类或接口的类加载器。
//public URL getResource(String name)返回:读取资源的 URL 对象;如果找不到该资源,或者调用者没有足够的权限获取该资源,则返回 null。
//此方法首先搜索资源的父类加载器;如果父类加载器为 null,则搜索的路径就是虚拟机的内置类加载器的路径。
//public String getPath()获取此 URL 的路径部分。
System.out.println(path);
dom = sax.read(new FileInputStream(path));
}catch (Exception e){
throw new RuntimeException(e.getMessage(), e);
}
}
/**
* @return 获取用户的Document
*/
public static Document getDocument(){
return dom;
}
/**
* 进行users.xml的保存,保存到本地
*/
public static void save(){
try {
XMLWriter w = new XMLWriter(new FileOutputStream(path));
w.write(dom);
w.close();
} catch (UnsupportedEncodingException e) {
throw new RuntimeException(e.getMessage(), e);
} catch (FileNotFoundException e) {
throw new RuntimeException(e.getMessage(), e);
} catch (IOException e) {
throw new RuntimeException(e.getMessage(), e);
}
}
/**
* 测试用
* @param args
*/
public static void main(String[] args){
System.out.println( getDocument() );
}
}
index.jsp:
<hr/>
<h2>以下演示一个小项目---用户注册</h2>
<h3>用户注册</h3>
<form action="/myServletDemo/reg" method="post">
姓名:<input type="text" name="name" /><br/>
密码:<input type="password" name="pwd"/><br/>
<input type='submit' value="注册"/>
</form>
<br/>
<a href="/servletDemo/reg">显示所有用户</a>
web.xml:
<servlet>
<servlet-name>RegServlet</servlet-name>
<servlet-class>cn.hncu.servlet.day2.RegServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>RegServlet</servlet-name>
<url-pattern>/reg</url-pattern>
</servlet-mapping>
<servlet>
<description>This is the description of my J2EE component</description>
<display-name>This is the display name of my J2EE component</display-name>
<servlet-name>DelServlet</servlet-name>
</servlet>
<servlet-mapping>
<servlet-name>DelServlet</servlet-name>
<url-pattern>/del</url-pattern>
</servlet-mapping>
RegServlet.java:用户注册:
package cn.hncu.servlet.day2;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.List;
import java.util.UUID;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.Node;
import cn.hncu.factory.Dom4jFactory;
public class RegServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=utf-8");
PrintWriter out = response.getWriter();
Document dom = Dom4jFactory.getDocument();
//获得所有用户信息
List<Element> users = dom.selectNodes("//user");
out.print("<html><body>");
for(Element e :users){
String id = e.attributeValue("id");
System.out.println(id);
String del = " <a href='/myServletDemo/del?id="+id+"'>删除</a>";
//System.out.println(e.attributeValue("name")+","+e.attributeValue("pwd"));
out.print("用户名:"+e.attributeValue("name")+",密码:"+e.attributeValue("pwd")+del+"<br/>");
}
out.print("<a href='javascript:history.go(-1);'>返回</a>");
out.print("</body></html>");
}
//处理用户注册的表单请求
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setCharacterEncoding("utf-8");
response.setContentType("text/html;charset=utf-8");
String name = request.getParameter("name");
String pwd = request.getParameter("pwd");
Document dom = Dom4jFactory.getDocument();
PrintWriter out = response.getWriter();
//防护,如果用户已经存在,就给前端发送换一个用户名的信息。
//xpath
Node node = dom.selectSingleNode("//user[@name='"+name.trim()+"']");
if(node!=null){//用户名已经存在,不能注册
out.print("该用户名已经存在,请换一个!");
//添加一个返回的链接
out.print(" <a href='javascript:history.go(-1);'>返回</a>");
}else{//可以注册
Element root = dom.getRootElement();
Element elem = root.addElement("user");
elem.addAttribute("id", UUID.randomUUID().toString().replaceAll("-", ""));
//replaceAll(String regex, String replacement) 使用给定的 replacement 替换此字符串所有匹配给定的正则表达式的子字符串。
elem.addAttribute("name", name);
elem.addAttribute("pwd", pwd);
//存
Dom4jFactory.save();
//返回注册成功
out.print("恭喜,注册成功。");
//添加一个返回的链接
out.print(" <a href='javascript:history.go(-1);'>返回</a>");
}
}
}
DelServlet.java-实现删除功能:
package cn.hncu.servlet.day2;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.dom4j.Document;
import org.dom4j.Node;
import cn.hncu.factory.Dom4jFactory;
public class DelServlet extends HttpServlet {
//只需要get方式就可以了。
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String delId = request.getParameter("id");
Document dom = Dom4jFactory.getDocument();
Node node = dom.selectSingleNode("//user[@id='"+delId+"']");
if(node!=null){
node.getParent().remove(node);
Dom4jFactory.save();
}
//重定向-继续返回当前页面
response.sendRedirect("/myServletDemo/reg");
}
}
id的传递用get方式传递的,?号后面的就是id。
演示结果:
注册一个name为张三的用户:
服务器中users.xml的绝对路径:
可以看到,多了一个user标签:
显示所有的用户:(多注册几个)
如果出现重名的情况:
删除链接:?号后跟着的是用户的id
点击删除后:用户被删除。
注意一点的是:
这个服务器中的users.xml文件和之前myeclipse中的users.xml已经不同了,你注册后,只会把服务器中的users.xml文件修改,而不会去改myeclipse中的users.xml文件,所以,如果你用myeclipse再重新发布,会把你服务器中的那个文件数据全部冲掉。。。。。注意哦。
Web---创建Servlet的3种方式、简单的用户注册功能的更多相关文章
- 创建servlet的三种方式
第一种方式,实现Servlet接口 package com.example.servlet; import java.io.IOException; import javax.servlet.Serv ...
- 用 Java 技术创建 RESTful Web (服务 JAX-RS:一种更为简单、可移植性更好的替代方式)
作者: Dustin Amrhein, 软件工程师, IBM Nick Gallardo, 软件工程师, IBM 出处: http://www.ibm.com/developerworks/cn/we ...
- 当阿里面试官问我:Java创建线程有几种方式?我就知道问题没那么简单
这是最新的大厂面试系列,还原真实场景,提炼出知识点分享给大家. 点赞再看,养成习惯~ 微信搜索[武哥聊编程],关注这个 Java 菜鸟. 昨天有个小伙伴去阿里面试实习生岗位,面试官问他了一个老生常谈的 ...
- 创建TabHost的两种方式的简单分析
最近做了一个TabHost的界面,在做的过程中发现了一些问题,故和大家分享一下. 首先我的界面如下: 目前就我所知,创建TabHost有两种方式,第一种是继承TabActivity类,然后用getTa ...
- SpringBoot整合Servlet的两种方式
SpringBoot整合Servlet有两种方式: 1.通过注解扫描完成Servlet组件的注册: 2.通过方法完成Servlet组件的注册: 现在简单记录一下两种方式的实现 1.通过注解扫描完成Se ...
- 实现web数据同步的四种方式
http://www.admin10000.com/document/6067.html 实现web数据同步的四种方式 1.nfs实现web数据共享 2.rsync +inotify实现web数据同步 ...
- linux下实现web数据同步的四种方式(性能比较)
实现web数据同步的四种方式 ======================================= 1.nfs实现web数据共享2.rsync +inotify实现web数据同步3.rsyn ...
- 【java并发】传统线程技术中创建线程的两种方式
传统的线程技术中有两种创建线程的方式:一是继承Thread类,并重写run()方法:二是实现Runnable接口,覆盖接口中的run()方法,并把Runnable接口的实现扔给Thread.这两种方式 ...
- Java创建线程的第二种方式:实现runable接口
/*需求:简单的卖票程序多个窗口买票 创建线程的第二种方式:实现runable接口 *//*步骤1.定义类实现Runable接口2.覆盖Runable接口中的run方法 将线程要运行的代码存放在 ...
随机推荐
- IniParse解析类
说明 iniParse这个类是一个解析ini文件的类,他的功能和Windows下GetPrivateProfileString的功能一样,可以很方便的保存读取配置. 当然他不是只有GetPrivate ...
- (转) oc static extern 和const
static 全局的,可以改的,如果在一个类中声明static,类中其他地方用到的时候,也是使用的改变量.和java类似,但不能用类名直接访问. const 是常量,不可以改的 extern 1.假如 ...
- Centos系统安装
Centos系统安装 安装系统前的注意事项 1) 硬件CPU必须支持虚拟化技术,在支持虚拟化的前提下我们还要去把虚拟 的功能打开否则在安装的时候会报错,开启虚拟化需要在BIOS中开启 2)创建虚拟机的 ...
- stream_context_create解决file_get_contents超时处理
stream_context_create作用:创建并返回一个文本数据流并应用各种选项,可用于fopen(),file_get_contents()等过程的超时设置.代理服务器.请求方式.头信息设置的 ...
- workerman安装
1.workerman安装 workerman是php的一个socket框架,简化了socket编程,已经为很多企业所用,今天在centos的ngix+php下安装了workerman,过程记录如下. ...
- juery mobile select下来菜单选项提交form问题
注意: data-native-menu="false" 虽然具有渲染作用,但是无法进行js提交. <script type="text/javascript&q ...
- 为什么很多语言选择在JVM上实现
非常经济地实现跨平台.你的语言编译器后端只需要输出 JVM 字节码就可以.跨平台需要极大的工作量,举个例子,只是独立开发生成本地代码,就需要花费大量精力去针对不同平台和处理器进行优化(比如 Firef ...
- loadView 与 ViewDidLoad
每个ios开发者对loadView和viewDidLoad肯定都很熟悉,虽然这两个函数使用上真的是非常简单,但是和类似的initWithNibName/awakeFromNib/initWithCod ...
- Delphi XE5 Device compatibility
Delphi XE5 Device compatibility https://docs.google.com/spreadsheet/ccc?key=0AoEN2CEsVvJ0dGhVaWJE ...
- git操作回顾:
1. git查看自己的本地分支: ***:~/mysite/mysite$ git branch * master 2. 查看远程分支: ***:~/mysite/mysite$ git branch ...