get方法和post方法的比较
1.首先建一个Servlet类(没有post和get方法时,一个service方法就可以替代)
package com.alex.servlet;
import java.io.IOException;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class LoginServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
public LoginServlet() {
super();
// TODO Auto-generated constructor stub
}
//shift + alt + s -> override implement method
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("get...");
super.doGet(req, resp);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("post...");
super.doPost(req, resp);
}
@Override
protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//解决post乱码问题
request.setCharacterEncoding("UTF-8");
//跳转页面servlet->jsp
response.setContentType("text/html;charset=UTF-8");
String uname= request.getParameter("uname");
String pwd= request.getParameter("pwd");
System.out.println("uname->"+uname);
System.out.println("pwd->"+pwd);
if(uname.equals("alex")&&pwd.equals("123")){
response.getWriter().println("登录成功");
}else{
response.getWriter().println("登录失败,用户名或密码不正确");
}
}
@Override
public void destroy() {
super.destroy();
}
@Override
public void init() throws ServletException {
super.init();
}
}
2.分别用get和post两种方法的Jsp页面向Servlet提交数据
1)get(method=“get”)Jsp页面
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>web project 02</title>
</head>
<body>
<form action="LoginServlet" method="get">
uname:<input type="text" name="uname" /><br />
pwd:<input type="password" name="pwd" /><br />
<input type="submit" value="提交" />
</form>
</body>
</html>
url 会显示参数(信息容易泄露,不安全);数据的传递是有限的不支持传递大量数据
2)post(method=“post”)Jsp页面
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>web project 02</title>
</head>
<body>
<form action="LoginServlet" method="post">
uname:<input type="text" name="uname" /><br />
pwd:<input type="password" name="pwd" /><br />
<input type="submit" value="提交" />
</form>
</body>
</html>
参数在url里面看不到了;支持传递大量数据