Web---演示servlet技术(servlet生命周期),解决中文乱码问题

简介: Web---演示servlet技术(servlet生命周期),解决中文乱码问题

本节讲解决中文乱码问题的4种方法。

还有更好的方法,也就是用过滤器,这里就不演示了,博主目前也不会~呼♪(^∇^*)~过段时间才会学。


servlet生命周期演示:


index.jsp:


<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
    <head>
        <title>
            演示servlet技术
        </title>
    </head>
    <body>
        <h2>演示servlet技术</h2>
        <a href="/myServletDemo/first">访问FirstServlet</a>
        <hr/>
    </body>
</html>


FirstServlet.java:

package cn.hncu.servlet;
import java.io.IOException;
import javax.servlet.Servlet;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
public class FirstServlet implements Servlet{
    //只有第一次访问才会被执行一次,最先执行一次!
    public FirstServlet() {
        System.out.println("1 构造方法被执行..."+this);
    }
    //关闭Tomcat服务器时会执行一次。如果是通过myeclipse关闭的,是不会执行的,因为是直接关闭了java虚拟机。
    //最后执行一次
    @Override
    public void destroy() {
        System.out.println("4 destroy..."+this);
    }
    @Override
    public ServletConfig getServletConfig() {
        return null;
    }
    @Override
    public String getServletInfo() {
        return null;
    }
    //第一次被访问才执行,在构造方法之后执行一次!
    @Override
    public void init(ServletConfig config) throws ServletException {
        System.out.println("2 init..."+this);
        String name = config.getInitParameter("name");
        System.out.println("name:"+name);
    }
    //每次访问都执行,(第一次)init()后执行
    @Override
    public void service(ServletRequest req, ServletResponse resp)
            throws ServletException, IOException {
        System.out.println("333 servlet"+this);
    }
}


web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0" 
    xmlns="http://java.sun.com/xml/ns/javaee" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
    http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
  <display-name></display-name> 
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
  <servlet>
    <servlet-name>firstServlet</servlet-name>
    <servlet-class>cn.hncu.servlet.FirstServlet</servlet-class>
    <init-param>
        <param-name>name</param-name>
        <param-value>Jack</param-value>
    </init-param>
  </servlet>
  <servlet-mapping>
    <servlet-name>firstServlet</servlet-name>
    <url-pattern>/first</url-pattern>
  </servlet-mapping>
</web-app>


配置需要初始化的参数:


<init-param>
    <param-name>name</param-name>
    <param-value>Jack</param-value>
</init-param>


在servlet中:

用config.getInitParameter(“name”);去得到name参数的值。


演示结果:


我们点击访问:访问FirstServlet

看后台的输出信息:

image.png



不关闭服务器再去访问:

image.png



用myeclipse关闭服务器-因为是直接关闭了java虚拟机,所以不会再运行destroy()方法。也就没有再输出。


image.png


用Tomcat的shutdown.bat关闭服务器:

image.png



解决中文乱码问题


index.jsp中增加:

<h2>以下演示用户登录</h2>
        <!-- 要向服务器传中文,前提是用post方式,get方式是肯定不行的 -->
        <form action="/myServlet/login" method="post">
            姓名:<input type="text" name="name"><br/>
            密码:<input type="password" name="pwd"><br/>
            <input type="submit" value="登录">        
        </form>

web.xml增加的代码:


<servlet>
    <servlet-name>login</servlet-name>
    <servlet-class>cn.hncu.servlet.LoginServlet</servlet-class>     
  </servlet>
  <servlet-mapping>
    <servlet-name>login</servlet-name>
    <url-pattern>/login</url-pattern>   
  </servlet-mapping>


LoginServlet.java:

package cn.hncu.servlet;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.Servlet;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
public class LoginServlet implements Servlet{
    @Override
    public void destroy() {
    }
    @Override
    public ServletConfig getServletConfig() {
        return null;
    }
    @Override
    public String getServletInfo() {
        return null;
    }
    private String charset = null;
    @Override
    public void init(ServletConfig config) throws ServletException {
        //法四:
        charset = config.getInitParameter("character");
    }
    @Override
    public void service(ServletRequest req, ServletResponse res)
            throws ServletException, IOException {
        //解决中文乱码问题
        //前提:前台页面必须以post方式提交中文---因为post会设置http协议头"Content-Type = application/x-www-form-urlencoded",
        //这样Tomcat才知道这是编码的字符数据
        //法一:在Tomcat的server.xml中的<Connect>中添加一个属性:URLEncoding="utf-8"
        //!!!法一是不可取的,因为Tomcat是公共平台,这个项目只是其中的一个项目,
        //不能把平台看成私有的即最好不要去修改,否则其他项目可能会出现问题
        //法二:把Tomcat解错的码还原回来
        //这个方法还行,但如果前台传输的很多参数都是中文,那么我们要对每个参数都要进行这样还原,显然比较麻烦。
        //还有,如果以后要改编码,就得改源代码,对客户来说比较麻烦。对程序员也一样
        //String name = req.getParameter("name");
        //byte bs[] = name.getBytes("iso8859-1");
        //name = new String(bs,"utf-8");
        //System.out.println(name);
        //法三:这种解决方式是比较好的,但有一个缺点:如果以后要改编码,就得改源代码,对客户来说比较麻烦。对程序员也一样
        //req.setCharacterEncoding("utf-8");
        //String name = req.getParameter("name");
        //法四:其实是在web.xml中把编码设置成参数,然后在这里读取出来,利用“法2”进行设置。以后如果要更改编码,只要更改web.xml中的相应参数设置就OK了
        req.setCharacterEncoding(charset);
        String name = req.getParameter("name");
        String pwd = req.getParameter("pwd");
        //用name和pwd到后台去访问数据库,以验证该用户信息是否正确(登录是否成功)
        //本例不是讲解这个,所以省略。
        res.setContentType("text/html;charset=utf-8");//告诉浏览器,我下面发的内容是什么格式的东西,什么编码的
        String html = "<html><body><font color='red'>name:</font>"+name+
                "<br/><font color='red'>pwd:</font>"+pwd+
                "</body></html>";
        PrintWriter out = res.getWriter();
        out.write(html);
        //*******另外一个小知识点:
        //Tomcat项目运行时,加载jar包或类文件的顺序:TOMCAT_HOME\lib  --> webapps\项目名\WEB-INF\lib  --> webapps\项目名\WEB-INF\classes目录下面的类
        //后加载的会覆盖前面的---即后加载有效-和java相反(父类加载机制)
    }
}

有2个小知识点:


1:

Tomcat项目运行时,加载jar包或类文件的顺序:TOMCAT_HOME\lib –> webapps\项目名\WEB-INF\lib –> webapps\项目名\WEB-INF\classes目录下面的类

后加载的会覆盖前面的—即后加载有效-和java相反(父类加载机制)


2:


<!-- 下面这句是用来在服务器启动的时候就new好servlet,也就是说,不用在等第一个客户访问的时候再new了。增加了访问速度。但同时增加了服务器的负荷 -->
    <!--15 这个数字是自己随便给的,如果有多个servlet 数字小的先new,也就是那个数字是决定newservlet的相对顺序的 -->
     <!-- <load-on-startup>15</load-on-startup> -->

加这个的位置是web.xml中,


image.png

演示结果:


一开始未写解决中文乱码时的演示结果:


image.png



后台显示:


image.png


用中文乱码解决时(不把每一种方法的结果都演示出来了)


image.png

image.png

image.png





目录
相关文章
|
16天前
|
SQL 缓存 搜索推荐
后端技术在现代Web开发中的应用与挑战
本文将深入探讨后端技术在现代Web开发中的重要性,涵盖从基础架构到性能优化的多个方面。通过分析当前主流后端技术的优缺点,并提供一些实用的解决方案和建议,帮助开发者更好地应对日常开发中的挑战。
33 1
|
7天前
|
前端开发 JavaScript 安全
深入理解Python Web开发中的前后端分离与WebSocket实时通信技术
在现代Web开发中,前后端分离已成为主流架构,通过解耦前端(用户界面)与后端(服务逻辑),提升了开发效率和团队协作。前端使用Vue.js、React等框架与后端通过HTTP/HTTPS通信,而WebSocket则实现了低延迟的全双工实时通信。本文结合Python框架如Flask和Django,探讨了前后端分离与WebSocket的最佳实践,包括明确接口规范、安全性考虑、性能优化及错误处理等方面,助力构建高效、实时且安全的Web应用。
20 2
|
11天前
|
Java 应用服务中间件 数据库连接
探索研究Servlet 生命周期
【9月更文挑战第22天】
34 7
|
10天前
|
前端开发 API Python
WebSocket技术详解:如何在Python Web应用中实现无缝实时通信
在Web开发的广阔领域中,实时通信已成为许多应用的核心需求。传统的HTTP请求-响应模型在实时性方面存在明显不足,而WebSocket作为一种在单个长连接上进行全双工通信的协议,为Web应用的实时通信提供了强有力的支持。本文将深入探讨WebSocket技术,并通过一个Python Web应用的案例分析,展示如何在Python中利用WebSocket实现无缝实时通信。
16 2
|
12天前
|
SQL 缓存 数据库
构建高效Web应用:掌握Python中的ORM映射技术
在Web开发中,数据库操作至关重要,但直接编写SQL语句会增加代码复杂度并降低效率。对象关系映射(ORM)技术通过将对象模型映射为数据库表,使开发者能以面向对象的方式处理数据,提升开发效率和代码可维护性。本文以Python和SQLAlchemy为例,介绍ORM的基本概念、安装方法及使用技巧,并展示其在提升Web应用性能方面的优势。通过ORM,开发者可以简化数据库操作,专注于业务逻辑实现,提高开发效率和代码质量。
35 1
|
21天前
|
安全 JavaScript Java
后端技术在现代Web开发中的实践与挑战
本文旨在探讨后端技术在现代Web开发中的关键作用,分析其在数据处理、业务逻辑实现和系统安全等方面的重要性。通过阐述常见的后端技术和框架,如Node.js、Django和Spring Boot,展示它们在实际项目中的应用。同时,文章将讨论后端开发所面临的主要挑战,包括性能优化、扩展性和维护性问题,以及如何应对这些挑战。最终,通过对实际案例的分析,总结出一套行之有效的后端开发最佳实践,为开发者提供参考。
48 5
|
21天前
|
人工智能 关系型数据库 数据安全/隐私保护
后端技术在现代Web开发中的应用与挑战
本文将深入探讨后端技术在现代Web开发中的重要性,通过分析其在数据处理、业务逻辑实现和安全性保障方面的应用,揭示后端技术的核心价值。同时,本文还将讨论当前后端开发面临的主要挑战,如高并发处理、数据安全、微服务架构的复杂性等,并给出相应的解决方案。无论是后端开发者还是对后端技术感兴趣的读者,都可以通过这篇文章获得启发和指导。
|
1月前
|
前端开发 安全 Java
技术进阶:使用Spring MVC构建适应未来的响应式Web应用
【9月更文挑战第2天】随着移动设备的普及,响应式设计至关重要。Spring MVC作为强大的Java Web框架,助力开发者创建适应多屏的应用。本文推荐使用Thymeleaf整合视图,通过简洁的HTML代码提高前端灵活性;采用`@ResponseBody`与`Callable`实现异步处理,优化应用响应速度;运用`@ControllerAdvice`统一异常管理,保持代码整洁;借助Jackson简化JSON处理;利用Spring Security增强安全性;并强调测试的重要性。遵循这些实践,将大幅提升开发效率和应用质量。
54 7
|
20天前
|
数据处理 Python
Django视图:构建动态Web页面的核心技术
Django视图:构建动态Web页面的核心技术
|
28天前
|
关系型数据库 Java MySQL
"解锁Java Web传奇之旅:从JDK1.8到Tomcat,再到MariaDB,一场跨越数据库的冒险安装盛宴,挑战你的技术极限!"
【9月更文挑战第6天】在Linux环境下安装JDK 1.8、Tomcat和MariaDB是搭建Java Web应用的关键步骤。本文详细介绍了使用apt-get安装OpenJDK 1.8、下载并配置Tomcat,以及安装和安全设置MariaDB(MySQL的开源分支)的方法。通过这些步骤,您可以快速构建一个稳定、高效的开发和部署环境,并验证各组件是否正确安装和运行。这为您的Java Web应用提供了一个坚实的基础。
35 0
下一篇
无影云桌面