JSP应用实践总结

简介: JSP应用实践总结

【1】插入样式

JSP页面插入CSS样式有三种方法,且其优先级不同。具体如下:外部样式,内部样式,内联样式。优先级依次增高!

① 外部样式

当样式需要应用于很多页面时,外部样式表将是理想的选择。在使用外部样式表的情况下,你可以通过改变一个文件来改变整个站点的外观。每个页面使用<link>标签链接到样式表。

<link rel="stylesheet" type="text/css" href="<%=uiPath%>hwtt_ui/skins/<%=skinName%>/css/login.css" />

rel 属性规定当前文档与被链接文档之间的关系,在该例子中rel 属性指示被链接的文档是一个样式表。

② 内部样式

当单个文档需要特殊的样式时,就应该使用内部样式表。可以使用<style>标签在文档头部定义内部样式表。

  <style type="text/css">
    .loginBtn{
      display:block;
        cursor: pointer;
        height: 32px;
        margin-bottom: 1px;
        width: 100px;
    }
  </style>

③ 内联样式

由于要将表现和内容混杂在一起,内联样式会损失掉样式表的许多优势。请慎用这种方法,例如当样式仅需要在一个元素上应用一次时。要使用内联样式,你需要在相关的标签内使用样式(style)属性。Style属性可以包含任何CSS属性。

<input type="text" name="authCode" style="vertical-align: middle" />

优先级:内联样式 > 内部样式 >外部样式!

【2】页面打印

页面加载启动打印

$(function(){
    document.execCommand('Print');
    //window.print();
    //打印当前窗口
});

利用WebBrowser

<OBJECT id = WebBrowser classid=CLSID:8856F961-340A-11D0-A96B-00C04FD705A2 height=0 width=0></OBJECT>
 <input type="button" value="打印" onclick=document.all.WebBrowser.ExecWB(6,1)/>
 <input type="button" value="直接打印" onclick=document.all.WebBrowser.ExecWB(6,6)/>
 <input type="button" value="页面设置" onclick=document.all.WebBrowser.ExecWB(8,1)/>
 <input type="button" value="打印预览" onclick=document.all.WebBrowser.ExecWB(7,1)/>

打印指定区域

function printTable(Id){
    var mstr;
    mStr = window.document.body.innerHTML;
    var mWindow = window;
    window.document.body.innerHTML = Id.innerHTML;
    mWindow.print();
    window.document.body.innerHTML = mStr;
  }
<body>
 <div id="print">
    //......
 </div>
 <input type="button" value="print" onclick="javascript:printTable(print);"/>
/*several use JS funciton ways*/
 <!--
    或者
    οnclick="return printTable(print);"
    或者
    οnclick="printTalbe(print);"
    或者
    $("input[type='button']:eq(0)").click(function(){
        printTable(print);
    });
-->
 </body>

【3】 页面注释的几种方式

① html注释

第一种-使用<!---->注释

<!--            
       <div position="center" title=""> 
       ...
-->

此时查看网页源代码可以看到注释的内容:

第二种-使用<%-- --%>注释

<%--            
        <div position="center" title=""> 
                <div style="text-align:left;line-height: 25px;margin-left: 100px;" >
                      <table style="width:90%;" class="css-querytable">
                          <tr>
                             </td>
                             ....
--%>

此时查看网页源代码看不到被注释的内容:


注意 html注释不可使用// 或 /* */

② 标签注释

着重指框架标签和JSTL标签

<%--
        <shiro:hasPermission name="user:unbind">
            toolData.push({text: '解绑',click: f_unbind, icon: 'busy'},{ line: true });
        </shiro:hasPermission>
--%>

<%-- --%>注释的表签内容在JSP解析为servlet时将会被忽略掉。

注意,不可使用// 或者 /* */ 或 <!-- -->标签。

③ JS注释

方式一:单行注释:// 多行注释: /* */

//          getCityArea('city',41,'',defaultCode)
//          f_getList(); 
/* 
            getCityArea('city',41,'',defaultCode)
            f_getList(); 
 */

此时查看网页源代码可以看到注释的内容:

方式二:<!---->注释

<!--        
            getCityArea('city',41,'',defaultCode)
            f_getList();
 -->

此时查看网页源代码同样可以看到被注释的内容。

方式三:<%-- --%>

<%--            
            getCityArea('city',41,'',defaultCode)
            f_getList(); 
 --%>

此时查看网页源代码将会看不到被注释的内容:

综上:

  • html注释不可以使用// 或 /* */
  • 标签注释只能使用<%-- --%>;
  • JS注释,上面四种标签都可以!
  • 其中,//或/* */同样适用于JAVA代码注释!


【4】FTL上注释


【5】表单提交的内容类型

从form的enctype属性到Content-Type再到request.getInputStream()。

写html的时候我们都知道form有个属性enctype,默认值是application/x-www-form-urlencoded,这个值表示会将表单数据用&符号做一个简单的拼接。例如:

POST /post_test.php HTTP/1.1   
Accept-Language: zh-CN  
User-Agent: Mozilla/4.0   
Content-Type: application/x-www-form-urlencoded   
Host: 192.168.12.102  
Content-Length: 42  
Connection: Keep-Alive  
Cache-Control: no-cache  
title=test&content=%B3%AC%BC%B6%C5%AE%C9%FA&submit=post+article  

我们注意到这个时候Content-Type为application/x-www-form-urlencoded。


如果enctype的值为multipart/form-data,这个值一般用于表单中包含文件上传的情况,它会将表单中的数据使用一个boundary作为分隔上传。例如:

POST /post_test.php?t=1 HTTP/1.1  
Accept-Language: zh-CN  
User-Agent: Mozilla/4.0    
Content-Type: multipart/form-data; boundary=---------------------------7dbf514701e8  
Accept-Encoding: gzip, deflate  
Host: 192.168.12.102  
Content-Length: 345  
Connection: Keep-Alive  
Cache-Control: no-cache  
-----------------------------7dbf514701e8  
Content-Disposition: form-data; name="title"  
test  
-----------------------------7dbf514701e8  
Content-Disposition: form-data; name="content"  
....  
-----------------------------7dbf514701e8  
Content-Disposition: form-data; name="submit"  
post article  
-----------------------------7dbf514701e8--  

我们注意到这个时候Content-Type也相应的变为multipart/form-data,同时后面还加上了分隔符boundary的描述。


所以,其实form的enctype属性某种程度上决定了Content-Type值和请求body里头的数据格式。


上面说到了form的处理情况,但是其实如果我们不是使用浏览器,而是自己实现的客户端来传递数据的话,这些头信息就得都由自己处理。所以上面就出现了,上传文件的时候仍然使用了application/x-www-form-urlencoded的不标准用法。

但是为啥Content-Type会影响request的处理呢?这得从request的一些实现说起。

request.getParameter()、 request.getInputStream()、request.getReader()这三种方法是有冲突的,因为流只能被读一次。

当form表单内容采用 enctype=application/x-www-form-urlencoded编码时,先通过调用request.getParameter() 方法得到参数后,再调用 request.getInputStream()或request.getReader()已经得不到流中的内容,因为在调用 request.getParameter()时系统可能对表单中提交的数 据以流的形式读了一次,反之亦然。


当form表单内容采用 enctype=multipart/form-data编码时,即使先调用request.getParameter()也得不到数据,但是这时调用 request.getParameter()方法对 request.getInputStream()或request.getReader()没有冲突,即使已经调用了 request.getParameter()方法也 可以通过调用request.getInputStream()或request.getReader()得 到表单中的数据,而request.getInputStream()和request.getReader()在同 一个响应中是不能混合使用的,如果混合使用就会抛异常。

从application/x- www-form-urlencoded到multipart/form-data


HTML中的form表单有一个关键属性 enctype=application/x-www-form-urlencoded 或multipart/form-data。


enctype=application/x- www-form-urlencoded是默认的编码方式,这种编码方式很简单,编码后的结果通常是 field1=value2&field2=value2&… 的形式,如 name=aaaa&Submit=Submit。


这种编码的具体规则可以在 rfc2231 里查到, 通常使用的表单也 是采用这种方式编码的,Servlet 的 API 提供了对这种 编码方式解码的支持,只需要调用 ServletRequest 类中的getParameter()方法就可 以得到用户表单中的字段和数据。

这种编码方式( application/x-www-form-urlencoded )虽然简单,但对于传输大块的二进制数据显得力不从心,对于传输这类数据,浏览器 采用了另一种编码方式,即 “multipart/form-data” 的编码方式,采用这种方式,浏览器可以很容易将表单内的数据和文件放在一起发送。


这种编码方式先定义好一个不可能在数据中出现的字符串作为 分界符,然后用它将各个数据段分开,而对于每个数据段都对应着 HTML 页面表单 中的一个 Input 区,包括一个 content-disposition 属性,说明了这个数据段的一些信息,如果这个数据段的内容是一个文件,还会有 Content-Type 属性,然后就是数据本身,如果以这种方式提交数据就要用request.getInputStream()或request.getReader()得到 提交的数据 ,用 request.getParameter()是得不到提交的数据的



目录
相关文章
|
7月前
|
存储 Java 关系型数据库
基于Servlet和JSP的Java Web应用开发指南
【6月更文挑战第23天】构建Java Web应用,Servlet与JSP携手打造在线图书管理系统,涵盖需求分析、设计、编码到测试。通过实例展示了Servlet如何处理用户登录(如`LoginServlet`),JSP负责页面展示(如`login.jsp`和`bookList.jsp`)。应用基于MySQL数据库,包含用户和图书表。登录失败显示错误信息,成功后展示图书列表。部署到Tomcat服务器测试功能。此基础教程为深入Java Web开发奠定了基础。
144 10
|
7月前
|
缓存 负载均衡 安全
Servlet与JSP在Java Web应用中的性能调优策略
【6月更文挑战第23天】在Java Web中,Servlet和JSP调优至关重要,以应对高并发和复杂业务带来的性能挑战。优化包括Servlet复用、线程安全、数据库连接池,以及JSP的编译优化、使用JSTL、页面缓存和静态内容分离。全局优化涉及负载均衡、异步处理和缓存策略。通过这些实践,开发者能提升应用响应速度和吞吐量,确保高负载下的稳定运行。
98 7
|
7月前
|
存储 缓存 安全
Servlet与JSP在Java服务器端开发中的实践与优化
【6月更文挑战第23天】本文探讨了Java中Servlet与JSP在在线书店系统开发中的应用,强调了它们在动态网站构建和Web效率中的作用。通过实例,展示了Servlet如何作为控制器处理用户登录,JSP则利用EL表达式呈现数据。此外,文章提及了性能优化如分页和缓存,以及安全措施如防止SQL注入和XSS攻击,强调了全面掌握和应用这些技术的重要性,以创建高效、安全的Web应用。
62 7
|
7月前
|
前端开发 小程序 Java
深入解析Java Servlet与JSP:构建高效服务器端应用
【6月更文挑战第23天】Java Servlet和JSP是Web开发的关键技术,用于构建高效服务器端应用。Servlet处理HTTP请求,执行业务逻辑,而JSP专注于动态HTML生成。两者结合,借助MVC架构,实现逻辑与视图分离,提高代码可读性和性能。尽管有新框架出现,Servlet和JSP仍是许多项目的基础。
142 7
|
8月前
|
前端开发 Java 数据库
【Spring原理进阶】SpringMVC调用链+JSP模板应用讲解
【Spring原理进阶】SpringMVC调用链+JSP模板应用讲解
|
8月前
|
SQL 前端开发 Java
JSP技术详解及其在Web开发中的应用
【1月更文挑战第2天】本文将对JSP(Java Server Pages)技术进行详细的介绍和分析。JSP是一种基于Java的服务器端编程技术,它允许开发者在HTML或XML等文档中直接嵌入Java代码片段,从而动态地生成Web页面内容。本文将首先阐述JSP的基本原理和工作机制,然后讨论其在Web开发中的各种应用场景,包括表单处理、数据库访问、会话管理等,并通过实例代码展示JSP的实际应用。最后,本文将对JSP的优缺点进行评述,并对未来的发展趋势进行展望。
796 10
|
Java 数据库
Jsp应用
Jsp应用
59 0
|
Java 数据安全/隐私保护
Shiro - JSP页面标签应用
Shiro - JSP页面标签应用
56 0
|
Java 物联网 Shell
Jsp Webshell在物联网的应用
Jsp Webshell在物联网的应用
|
Java 关系型数据库 MySQL
JSP实践教学平台系统myeclipse开发mysql数据库bs框架java编程jdbc
JSP 实践教学平台系统是一套完善的web设计系统,对理解JSP java编程开发语言有帮助,系统具有完整的源代码和数据库,开发环境为TOMCAT7.0,Myeclipse8.5开发,数据库为Mysql5.0,数据库文件名是jspskcsjpt.sql,系统名称kcsjpt,使用java语言开发系统主要采用B/S模式开发。
84 0