Javaweb

作者: 子约nan | 来源:发表于2017-11-12 19:40 被阅读0次

servlet介绍

Servlet是一个java类及接口,当Web应用运行在服务器上时负责接收客户端(Client)向服务器发起的HTTP请求(Request),然后再根据需要向客户端返回HTTP响应(Response)。

配置web.xml文件

<servlet>
    <servlet-name>classtable</servlet-name>
    <servlet-class>com.first.Classtable.classtable</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>classtable</servlet-name>
    <url-pattern>/classtable</url-pattern>
  </servlet-mapping>

servlet类

package com.classtable.servlet;

import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.mysql.jdbc.Driver;

public class Query extends HttpServlet {
    public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {      
        request.setCharacterEncoding("utf-8");
        String str = request.getParameter("class");                         
        try {
            DriverManager.registerDriver(new com.mysql.jdbc.Driver());
            Connection conn =(Connection) DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/nf", "root", "148315");          
            Statement stmt = (Statement) conn.createStatement();
            String sql = "SELECT classCode FROM class WHERE className ='"+str+"'";
            ResultSet rs = stmt.executeQuery(sql);
            String code  = null;            
            if(rs.next()){              
                code = rs.getString("classCode");               
            }       
            sql = "select section,one,two,three,four,five,six,seven from timetable where classCode = '"+code+"'and semester ='17-18-1'";
            rs = stmt.executeQuery(sql);
            
            StringBuffer sb = new StringBuffer();
            while(rs.next()){               
                sb.append(rs.getString("section")+rs.getString("one")+rs.getString("two")+rs.getString("three")+rs.getString("four")+rs.getString("five")+rs.getString("six")+rs.getString("seven"));
                
            }           
            String data = sb.toString();
            response.setCharacterEncoding("utf-8");
            response.setContentType("text/html;charset = utf-8");
            PrintWriter pw = response.getWriter();
            pw.write(data); 
            
        } catch (SQLException e) {
            e.printStackTrace();            
        }
    }   
    public void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
           doGet(request,response);
    
    }

}

Classtable.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ page contentType="text/html; charset=UTF-8"  %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
  </head>
  <body>
  <%
    ServletContext context = this.getServletContext();
       List<classbean>TL=new ArrayList<classbean>();
         TL=(List<classbean>)context.getAttribute("CLASSLIST");
  %>
    <table border="2" align="center" width="90%" cellpadding="2" cellspacing="2">
        <caption><h2>我的课表</h2></caption>
        <thead>             
                <td>学期</td>
                <td>班级</td>
                <td>数</td>
                <td>星期一</td>
                <td>星期二</td>
                <td>星期三</td>
                <td>星期四</td>
                <td>星期五</td>
                <td>星期六</td>
                <td>星期日</td>                                
        </thead>
        <tbody>
        <%
            for(classbean L:TL){
        %>
            <tr>
            <td><%=L.getsemester()%></td>
            <td><%=L.getclassCode()%></td>
            <td><%=L.getSection()%></td>
            <td><%=L.getOne()%></td>
            <td><%=L.getTwo()%></td>
            <td><%=L.getfour()%></td>
            <td><%=L.getfive()%></td>
            <td><%=L.getsix()%></td>
            <td><%=L.getseven()%></td>
        
            </tr>
        <%} %>
        </tbody>
    </table>
  </body>
</html>

get和post的特点及其区别----体现在所传递的参数上面

  • get()方式传参的特点
    (1)参数直接放在请求url后面
    (2)从浏览器的地址栏里面可以直接看到所传的参数
    (3)参数的长度有限制,不能把一个很长的数据通过get方式传参
  • post()这种方式传参的特点
    (1).参数放在请求的体部而不是url后面.
    (2).浏览器的地址栏中看不到所传的参数.
    (3).因为参数不用出现在地址栏里面,所有参数长度是没有限制的.
    9、 中文乱码问题:
    同意格式为字符编码格式:utf-8
    (1)设置浏览器的编码格式为:utf-8
    (2)在tommact服务器中,在conf文件中设置编码格式:
    <Connector URIEncoding="UTF-8" connectionTimeout="20000" port="8888" protocol="HTTP/1.1" redirectPort="8443"/>
    (3)在web.xml、servlet中,点击 alt+回车 快捷键 :设置编码格式
    (4) 在servlet代码中,设置req/resp 的字符编码格式:req.setCharacterEncoding("UTF-8");
    指定浏览器传输的数据是用特定编码格式:req.setContentType("text/html;charset=UTF-8");
    常见错误及其解决
  • 400错误:404产生的原因为Web服务器(容器)根据请求地址找不到对应资源,以下情况都会出现404的错误提示:
    输入的地址有误(应用名大小写不正确,名称拼写不正确) 在web.xml文件中<servlet>和<servlet-mapping>中的两个<servlet-name>不一致 没有将工程部署到Tomcat的webapps下面 Web工程部署时的结构没有遵循Servlet的规范。
  • 500错误: 500的错误原因是请求的Servlet在执行service方法的过程中出现了错误,程序不能继续运行了。
    Servlet没有继承HttpServlet或实现Servlet接口, web.xml文件中的<servlet-class>写错,与真正的包名类名不符 ,service方法中的代码运行时抛出异常 .

相关文章

网友评论

      本文标题:Javaweb

      本文链接:https://www.haomeiwen.com/subject/lwscmxtx.html