什么是JSP

JSP 是Java Server Papes(Java 服务器系统页面)的缩写,它是由Sun Microsystems 公司倡导的、许多公司参与一起建立的一种动态网页技术标准,其在动态网页的创建中有强大而特殊的功能,Java Server Pages(JSP)是一种实现普通静态HTML 和动态HTML 混合编码的技术。所有程序操作都在服务器端执行,网络上传送给客户端的仅是得到的结果,这样大大降低了对客户浏览器的要求,即使客户浏览器不支持Java,也可以访问JSP 网页。

JSP 的优点

1.把应用程序内容与页面显示分离

应用JSP 技术,Web 页面开发者可以使用HTML 或者XML 标签来设计和格式化最终页面,使用JSP 标签或者Scriptlet 来生成页面上的由请求而变化的动态内容(例如请求用户数据或者指定的对象的属性)。生成内容的逻辑被封装在标签和JavaBean 组件中,并且捆绑在Scriptlet 中,所有的脚本程序都运行在服务器端。这样Web 管理人员和页面开发者,能够编辑和使用JSP 页面,而不影响内容的生成。

在服务器端,由JSP 引擎解释JSP 标签和Scriptlet,生成所请求的内容(例如,通过访问JavaBean 组件,使用JDBC 技术访问数据库,或者访问文件),并且将结果以HTML(或者XML)页面的形式发送回浏览器。这样既可以保护作者自己的程序代码,又可以保证任何基于HTML 的Web 浏览器能够解析。与Servlet 相比,JSP 能提供所有Servlet 的功能,但它比用println 编写和修改HTML更方便。此外,还可以更明确地进行分工,Web 页面样式设计人员编写HTML,然后留出地方让Servlet 程序员插入动态部分。

2.一次编写,到处运行

由于JSP 页面由HTML 代码和嵌入其中的Java 代码所组成,并且所有的JSP 页面都要被编译成为Servlet,JSP 页面就具有Java 技术的所有优点,包括健壮的存储管理和安全性等。其中最重要的一点就是“一次编写,到处运行”,除了系统之外,代码不用做任何更改。JSP 技术是与设计平台完全无关的,包括它的动态Web 页面,它的Web 服务器和底层的服务器组件。可以在任何平台上编写JSP 页面,在任何Web 服务器或者Web 应用服务器上运行,或者通过任何Web 浏览器访问。还可以在任何平台上建立服务器组件并且在任何服务器上运行它们,目前主要是JavaBean 和Servlet。越来越多的供应商将JSP 支持添加到他们的产品中,用户便可以使用自己所选择的服务器和工具,更改工具或服务器不会影响到当前的应用。

3.强调可重用的组件

绝大多数JSP 页面依赖于可重用的、跨平台的组件(JavaBeans 或者企业版的JavaBeans

组件)来执行应用程序中所要求的更为复杂的处理。开发人员能够共享和交换执行普通操

作的组件,或者使得这些组件为更多的使用者或者客户团体所使用。这些组件有助于将网

页的设计与逻辑程序的编写分开,节约了开发时间,同时充分发挥了Java 和其他脚本语言

的跨平台的能力和灵活性。基于组件的方法加速了总体开发过程,并且使得各种组织在他

们现有的技能和优化结果的开发努力中得到平衡。

4.采用标记简化页面的开发

Web 页面开发人员不一定都是熟悉脚本语言的编程人员。JSP 技术封装了许多功能,这些功能是在易用的、与JSP 相关的XML 标记中进行动态内容生成时所必需的。标准的JSP标记能够访问和实例化JavaBean 组件,设置或者检索组件属性,下载Applet,以及执行用其他方法更难于编码和耗时的功能。

在JSP 的众多优点之一是它能把HTML 编码和业务逻辑有效地分离。通常,JSP 负责生成动态HTML 页面,业务逻辑由其他可重用的组件(如Servlet、JavaBean)和其他Java程序来实现,JSP 可以通过Java 程序片段访问这些业务组件。JSP 访问服务器端可重用组件的模型如图3-1 所示。

JSP页面实现验证码校验

在网页页面的使用中为防止“非人类”的大量操作和防止一些的信息冗余,增加验证码校验是许多网站常用的方式。

而让用户输入字母和数字组合的验证码是最经典也是最常用的方式。这一篇是纯利用现有JDK提供的绘图类(ImageIO)类制作,这个过程比较复杂且需要了解ImageIO类。

今天发布的第二篇文章是利用Hutool工具类来实现的,该工具类已经封装验证码所需的相关类等,使用起来较为简单和方便。

验证码的生成和校验过程均使用Servlet和JSP的结合来实现,Servlet的相关内容可以参阅

Servlet技术:

如何利用基础的JSP知识来实现网页的验证码校验呢?

首先要验证码的校验的过程。

验证码校验分为三部分:

  1. 生成验证码
  2. 获取用户输入的验证码
  3. 判断验证码是否输入正确

验证码的生成实际就是输出一个图像,所以在这里使用ImageIO来生成图片,然后结合使用随机数(Random)来实现随机生成验证上的内容,最后进而展示出来,然后利用Session对象存储验证码的内容。在用户输入验证码的时候可以用request来获取用户输入的内容,让其余Session对象中保存的验证码内容进行比较,若一致则验证成功,不一致就验证失败。

先创建一个图片的缓冲区:

创建画布:

创建颜色:

创建背景颜色:

填充矩形:

将要显示的验证码内容组成元素存入字符串数组:

创建随机的验证码内容:

将验证码的内容存入Session及显示在页面上:

完整代码:

在测试之前需要先在web.xml文件中配置一下:

启动服务器后在浏览器中输入http://localhost:8080/工程名/imageServlet 即可

验证码的生成已经实现成功,下面实现验证验证码的Servlet。

先新建一个jsp用户界面:

校验验证码过程:

  1. 将生成的验证码内容保存在Session对象中
  2. 获取用户输入的验证码内容
  3. 将两个内容进行对照

代码实现:

获取Session中的验证码内容:

获取用户输入的验证码内容:

验证码判断(使用了PrintWriter将相关内容输出)

完整代码:

测试前先在web.xml文件中配置一下:

在验证码生成之后,用户在识别的时候可能不能正确识别,这时候就需要刷新一下重新生成。

添加超链接实现刷新:

login.jsp:

js部分的Date相关是防止浏览器缓存后不能正常刷新,添加时间的唯一性来实现能够及时刷新和展示。

js 部分可以参阅:JavaScript 语言入门:

也可以在ImageServlet中添加防止浏览器缓存的语句:

公众号本文地址:

欢迎关注公众号:愚生浅末。

实战:Springboot集成jsp页面报404四种解决方案

Springboot集成jsp页面报404。最近搭建一个简单的Springboot+maven+jsp的项目时,出现访问jsp页面时一直出404,错误信息是:

翻译过来:

网上找了一些解决方案:

不符合,pass掉

不符合,pass掉

没有配置端口,使用默认8080:所以访问地址是:

不符合,pass掉

修改箭头所指的为当前内容即可。如何没有该选项,maven clean 和 compile 完毕即可看到该内容。

作者:java小丑

原文链接:https://blog.csdn.net/java_wxid/article/details/105530437

本文作者及来源:Renderbus瑞云渲染农场https://www.renderbus.com

点赞 0
收藏 0

文章为作者独立观点不代本网立场,未经允许不得转载。