zoukankan      html  css  js  c++  java
  • 马士兵 Servlet_JSP(2) JSP源代码)

    1.最简单的JSP

    HelloWorld.jsp

    <html>
        <head>
            <title>Hello</title>
            <body>
                <%
                    out.println("Hello World!");
                %>
            </body>
        </head>
    </html>


    ---------------------------------------------------------------------------------------------------------------------------------------


    2.JSP中的全局变量和局部变量


    AccessCounts.jsp


    <html>
        <head>
            <title>JSP Declaration</title>
        </head>
        <body>
            <%!
                // 全局变量
                int accessCount = 0;
            %>
            
            <%
                // 局部变量
                int accessCount2 = 0;
            %>
            
            <h2>AccessCount:
                <br>Overall Variable:<%= ++accessCount %>
                <br>Local Variable:<%= ++accessCount2 %>
            </h2>
            
        </body>
    </html>


    测试结果:访问同一页面,每刷新一次,accessCount增1,accessCount2不变(每次出现一个新的局部变量)。


    ----------------------------------------------------------------------------------------------------------------------------------


    3.注释、当前页面从URL中取背景色参数


    BGColor.jsp


    <html>
        <head>
            <title>Color Testing</title>
        </head>
        
        <!--
        HTML注释
        客户端可以看见
        -->
        
        <%--
        JSP注释
        客户端看不见
        --%>
        
        
        <%
        //注释2
        /*
        注释3
        */
        // 将请求中参数bgColor的值拿过来,假如没有传这个参数,则值为null
        String bgColor = request.getParameter("bgColor");
        boolean hasColor;
        if(bgColor != null) {
            hasColor = true;
        } else {
            hasColor = false;
            bgColor = "white";
        }
        %>
            
            <!--显示背景色-->
        <body bgcolor="<%= bgColor%>">
        <h2 align="center">Color Testing</h2>
        
        <%
        if(hasColor) {
            out.println("You supplied a backgroud color of " + bgColor + ".");
        } else {
            out.println("Use Default backgroud color of white");
        }
        %>
            
        </body>
    </html>




    -----------------------------------------------------------------------------------------------------------------------------




    4.表达式


    Expressions.jsp


    <html>
        <head>
            <title>JSP Expressions</title>
        </head>
        <!--表达式-->
        <body>
            <h2>JSP Expressions</h2>
            
        <UL>
            <!--获取当前本地时间-->
            <LI>Current Time:<%= new java.util.Date().toLocaleString() %>
            <LI>Your HostName:<%= request.getRemoteHost() %>
            <!--获取当前页面的SessionID-->
            <LI>Your Session Id:<%= session.getId() %>
            <LI>The <code>testParam</code> from parameter:<%= request.getParameter("testParam") %>
        </UL>
        
        </body>
    </html>


    ----------------------------------------------------------------------------------------------------------------------------------------


    5.@page指示语句的测试


    TestDirective.jsp


    <%@page import="java.util.*" %>
    <%@page contentType="text/html;charset=gb2312" %>
        <!--@page指示语句的测试-->
        <!--将当前系统时间转变成我们本地常用的形式输出-->
    <%= new Date().toLocaleString() %>
    <br><br>
    <%
        out.println("你好!"); 
    %>




    --------------------------------------------------------------------------------------------------------------------------------


    6.错误页跳转测试


    ①TestErr.jsp


    <%@page errorPage="ErrPage.jsp" %>
    <!--如果本页面出错则跳转到ErrPage.jsp页面-->
    <%
    String str = "123abc";
    int i = Integer.parseInt(str);
    out.println("str= " + str + ",i= " + i);
    %>


    ②ErrPage.jsp


    <%@page contentType="text/html;charset=gb2312" %>
    <%@page isErrorPage="true" %>
    <!--本页面是个错误信息显示页-->
    <html>
        <body text="red">
            错误信息:<%= exception.getMessage()%>
        </body>
    </html>




    -----------------------------------------------------------------------------------------------------------------------------


    7.include指令”%@ include file“和include动作指令“jsp:include page”


    前者是先包含进来再编译执行;后者是先各自编译执行再包含进来


    ①include.jsp


    <html>
        <head>
            <title>include test</title>
        </head>
        
        <body bgcolor="white">
            <font color="red">
                The current time and date are:<br>
            <!--先将date.jsp的内容包含进来,再一起进行转换、编译和执行-->
                <%@include file="date.jsp" %><br>
            <!--先将date.jsp进行转换、编译和执行,再将结果包含进来-->
                <jsp:include page="date.jsp" flush="true" />
            </font>
        </body>
    </html>


    ②date.jsp


    <%@page import="java.util.*" %>
    <%--a string representation of this date, using the locale conventions.--%>
    <%= (new Date()).toLocaleString() %>


    说明:以下转载自网络   http://blog.matrix.org.cn/rudy541/entry/200708162
    jsp中两种包含文件的区别:


    相同点:两者逗能包含一个页面
    不同点:
    区别1:
    <jsp:include page="b.jsp" />(先执行,后包含)
    此标签表示法:能动态区别加进来的是动态页面还是静态页面
    对于静态页面则直接将资源包含(仅取其文本)。
    对于动态页面则先处理各自资源,之后将处理过的结果包含在一起。


    <%@ include file="b.jsp">
    此指令表示:静态地包含页面,不管其内容如何,不过是静态页面还是动态页面都首先将页面的内容先加进来。
    然后一起处理,再将所有内容发给客户端。
    实例挑战:
    有b.jsp页面
    <%int i = 10 ;%>
    <%=i%>
    主界面a.jsp也有<%int i = 100 ;%>        <%=i%>
    如果是加载<%@ include file="b.jsp">,则是先包含后执行,就会发现报错,i被重新定义,
    但如果是加载<jsp:include page="b.jsp" />则是先执行结果,然后将结果包括到主页面。不会报错。
    区别2:
    <jsp:include page="b.jsp" />可以分开写成:
    <jsp:include page="b.jsp" >
    <jsp:param name="参数名" value="参数值"/>
    </jsp:include>
    这样就可以传递参数。




    ----------------------------------------------------------------------------------------------------------------------


    8.两个数的乘除运算


    ①Compute.html


    <html>
        <head>
            <title>Compute</title>
            <meta http-equiv="Content-Type" content="text/html;charset=gb2312">
        </head>
        <!--两个数的乘除运算-->
        <body bgcolor="#FFFFFF">
            <div align="center">
                <form method="post" action="Compute.jsp">
                    <p>选择要做的运算:
                        <input type="radio" name="compute" value="division" checked>
                        除法
                        <input type="radio" name="compute" value="multiplication">
                        乘法
                    </p>
                    <p>被除数(被乘数)
                        <input type="text" name="value1">
                        除数(乘数)
                        <input type="text" name="value2">
                    </p>
                    <p>
                        <input type="submit" name="Submit" value="计算结果">
                    </p>
                </form>
            </div>
        </body>
    </html>


    ②Compute.jsp


    <%@page language="java" %>
    <%@page contentType="text/html;charset=gb2312" %>


    <%
        // 将Compute.html页面输入的要进行计算的两个变量拿过来
        String value1 = request.getParameter("value1");
        String value2 = request.getParameter("value2");
    %>


    <% if("division".equals(request.getParameter("compute"))) { %>
        <!--进行除法计算,把两个参数v1和v2先传到divide.jsp,再那边编译运行,然后把结果拿到这边显示出来-->
            <jsp:include page="divide.jsp" flush="true">
                <jsp:param name="v1" value="<%=value1%>"/>
                <jsp:param name="v2" value="<%=value2%>"/>
            </jsp:include>
    <%    } else { %>
            <!--直接把multiply.jsp拿过来,跟本页面一起编译执行-->
            <%@include file="multiply.jsp" %>
    <%    } %>




    ③multiply.jsp


    <%@page contentType="text/html;charset=gb2312" %>
    <html>
        <head>
            <title>Multiply</title>
        </head>
        <%--进行乘法计算的JSP--%>
        <body bgcolor="#FFFFFF">
            <center>
                <h1>
                    <%
                        try{
                            float multiplicand = Float.parseFloat(request.getParameter("value1"));
                            float multiplicator = Float.parseFloat(request.getParameter("value2"));
                            double result = multiplicand*multiplicator;
                            out.println(multiplicand + "*" + multiplicator +" = " + result);
                        } catch(Exception e) {
                            out.println("不合法的乘数或被乘数");
                        }
                    %>
                </h1>
            </center>
        </body>
    </html>


    ④divide.jsp


    <%@page contentType="text/html;charset=gb2312" %>
    <html>
        <head>
            <title>Divide</title>
        </head>
        <%--进行除法计算的JSP--%>
        <body bgcolor="#FFFFFF">
            <center>
                <h1>
                    <%
                        try{
                            float divident = Float.parseFloat(request.getParameter("v1"));
                            float divisor = Float.parseFloat(request.getParameter("v2"));
                            double result = divident/divisor;
                            %>
                            <%= result%>
                            <%
                        } catch(Exception e) {
                            out.println("不合法的除数或被除数");
                        }
                    %>
                </h1>
            </center>
        </body>
    </html>


    ----------------------------------------------------------------------------------------------------------------------------------


    9.jsp:forward和response.sendRedirect


    ①最简单的jsp:forward


    forward.jsp


    <html>
        <head>
            <title>Forward Example</title>
        </head>
        <!--最终显示的是forforward.jsp中的内容-->
        <body bgcolor=red>
            Welcome to forward.jsp
            <%--直接跳转到forforward.jsp,这两个jsp用的是同一个request--%>
            <jsp:forward page="forforward.jsp" />
        </body>
    </html>


    forforward.jsp


    <html>
        <head>
            <title>forforward.jsp</title>
        </head>
        
        <body bgcolor=blue>
            Welcome<br>
            Here is forforward.jsp
        </body>
    </html>


    ②jsp:forward和response.sendRedirect的比较


    forward1.jsp


    <html>
        <head>
            <title>Forward Example</title>
        </head>
        
        <body bgcolor=red>
            Welcome to forward1.jsp
            <jsp:forward page="forforward1.jsp" >
                <jsp:param name="name" value="m" />
                <jsp:param name="oldName" value='<%= request.getParameter("name")%>' />
                <jsp:param name="roles" value="manager" />
            </jsp:forward>
        </body>
    </html>


    forforward1.jsp:和forward1.jsp使用的是同一个request(服务器跳转)


    <html>
        <head>
            <title>forforward1.jsp</title>
        </head>
        
        <body bgcolor=blue>
            Welcome<br>
            Here is forforward1.jsp<br>
            <%= request.getParameter("name")%>
            <%= request.getParameter("oldName")%>
            <%= request.getParameter("roles")%>
            <%= request.getParameter("address")%>
        </body>
    </html>


    测试结果:
    访问http://localhost:8888/test/forward/forward1.jsp?name=yyg&address=34527144231
    结果:
    Welcome
    Here is forforward1.jsp
    m yyg manager 34527144231 


    此时页面URL还是forward1.jsp,并没有跳转到forforward1.jsp,给用户的感觉还是刚才的页面在为自己服务。
    说明:m 和manager 是forward1.jsp中传过来的;而yyg 和34527144231 是在URL中通过request传过来的。并且forward1.jsp中也没有address属性,这也从另一个角度说明了这两个jsp使用的是同一个request。




    test.jsp:和forward1.jsp使用的是不同的request
    说明:访问过http://localhost:8888/test/forward/test.jsp后,页面跳转成http://localhost:8888/test/forward/forforward1.jsp
    这个过程中客户和服务器之间产生了两个request,并且test.jsp后跟参数并不能传递到forforward1.jsp(原因也很明显:两次是不同的request)


    <%
        response.sendRedirect("forforward1.jsp");
    %>




    ---------------------------------------------------------------------------------------------------------------------------------------------


    10.jsp:useBean


    ①CounterBean.java


    package bean;


    import java.io.Serializable;


    /**
     * 一个很普通的JavaBean
     * @author jukey
     *
     */
    public class CounterBean implements Serializable {
        
        private int count = 0;


        public CounterBean() {}


        public int getCount() {
            count++;
            return count;
        }


        public void setCount(int count) {
            this.count = count;
        }
    }


    ②test.jsp:JSP往JavaBean中设置值,从JavaBean中拿值


    <%@page import="bean.*" %>


    <%--
    <%
        // 下面这个语句等同于<jsp:useBean id="cb" class="bean.CounterBean"></jsp:useBean>
        CounterBean cb = new CounterBean();
    %>
    --%>


    <jsp:useBean id="cb" class="bean.CounterBean">
    </jsp:useBean>


    <font color="red" size="5">
        <%--将bean中存储的值拿出来--%>
        <%= cb.getCount()%>
    </font>


    <!--往bean中存值-->
    <jsp:setProperty name="cb" property="count" value="25" />
        <%--cb.setCount(25)--%>
        
    <!--往bean中取值-->
    <jsp:getProperty name="cb" property="count" />
        <%--cb.getCount()--%>




    以下是Bean的4种作用范围的测试:


    ③page有效(仅涵盖使用JavaBean的页面)


    PageBean.jsp


    <jsp:useBean id="counterBean" scope="page" class="bean.CounterBean" />
        
    <html>
        <body>
            <h3>CounterBean scope="page" Example</h3>
            <b>count:</b> <%= counterBean.getCount()%>
        <%--上下两句效果一样--%>
            <jsp:getProperty name="counterBean" property="count"/>
        </body>
    </html>


    ④request有效(有效范围仅限于使用JavaBean的请求)


    RequestBean.jsp




    <jsp:useBean id="counterBean" scope="request" class="bean.CounterBean" />
        
    <%--
        bean.CounterBean counterBean = request.getAttribute("counterBean");
        if(counterBean == null) {
            counterBean = new bean.CounterBean();
            request.setAttribute("counterBean",counterBean);
        }
    --%>
        
    <html>
        <body>
            <h3>CounterBean scope="request" Example</h3>
        <!--往当前request对应的bean中设置-->
            <% counterBean.setCount(100); %>
            <%--和RequestBean2.jsp用的是同一个request,也是同一个counterBean对象--%>
                <!--测试结果是101-->
            <jsp:forward page="RequestBean2.jsp" /> 
                
                <%--和RequestBean2.jsp用的不是同一个request,也不是同一个counterBean对象--%>
                    <!--访问RequestBean.jsp,跳转到RequestBean2.jsp,因为和当前request不是同一个request-->
                    <!--则产生一个新的request,产生一个新的bean对象,测试结果是1而不是101-->
            <%-- response.sendRedirect("RequestBean2.jsp"); --%>
        </body>
    </html>




    RequestBean2.jsp




    <jsp:useBean id="counterBean" scope="request" class="bean.CounterBean" />
        
    <html>
        <body>
            <h3>CounterBean scope="request" Example</h3>
            <b>count:</b> <%= counterBean.getCount()%>
        </body>
    </html>




    ⑤Session有效(有效范围在用户整个连接过程中,整个会话阶段均有效)


    SessionBean.jsp




    <jsp:useBean id="counterBean" scope="session" class="bean.CounterBean" />
        
    <%--
        // 这一段java代码等同于上面这句JSP语句
        bean.CounterBean counterBean = session.getAttribute("counterBean");
        if(counterBean == null) {
            counterBean = new bean.CounterBean();
            session.setAttribute("counterBean",counterBean);
        }
    --%>


    <html>
        <body>
            <h3>CounterBean scope="session" Example</h3>
            <b>count:</b> <%= counterBean.getCount()%>
        </body>
    </html>




    SessionBean2.jsp




    <jsp:useBean id="counterBean" scope="session" class="bean.CounterBean" />
        
    <html>
        <body>
            <h3>CounterBean scope="session" Example</h3>
            <b>count:</b> <%= counterBean.getCount()%>
        </body>
    </html>






    ⑥application有效(有效范围涵盖整个应用程序,也就是对整个网站都有效)
    可用于作为首页访问量的计数器


    ApplicationBean.jsp




    <jsp:useBean id="counterBean" scope="application" class="bean.CounterBean" />
        
    <html>
        <body>
            <h3>CounterBean scope="application" Example</h3>
            <b>count:</b> <%= counterBean.getCount()%>
        </body>
    </html>




    ApplicationBean2.jsp




    <jsp:useBean id="counterBean" scope="application" class="bean.CounterBean" />
        
    <html>
        <body>
            <h3>CounterBean scope="application" Example</h3>
            <b>count:</b> <%= counterBean.getCount()%>
        </body>
    </html>


    ----------------------------------------------------------------------------------------------------------------------


    11.jsp:setProperty和jsp:getProperty


    ①SaleEntry.jsp


    <html>
        <head>
            <title>Using jsp:setProperty</title>
        </head>
        <!--销售条目(单行:商品编号、单价、数量、总价)-->
        <body>
            <table border=5 align="center" >
                <tr><th class="title">
                    Using jsp:setProperty
            </table>
            
            <jsp:useBean id="entry" class="bean.SaleEntry" />
            
            <%--从JSP向JavaBean中设值--%>    
    <!--通过param指定表单元素的名称,通过property指定bean的属性名称,由此建立两个变量的关联-->
            <jsp:setProperty name="entry" property="itemID" value="<%= request.getParameter("itemID")%>" />
            <jsp:setProperty name="entry" property="numItems" param="numItems" />
            <jsp:setProperty name="entry" property="discountCode" param="discountCode" />
                        
            <br>
            
            <table border=1 align="center" >
                <tr class="colored">
                    <th>Item ID<th>Unit Price<th>Number Ordered<th>Total Price
                <tr align="right">
                    <%--Jsp从JavaBean中取值--%>
                    <td><jsp:getProperty name="entry" property="itemID" />
                    <td>$<jsp:getProperty name="entry" property="itemCost" />
                    <td><jsp:getProperty name="entry" property="numItems" />
                    <td>$<jsp:getProperty name="entry" property="totalCost" />
            </table>
        </body>
    </html>


    ②SaleEntry.java


    package bean;


    public class SaleEntry {
        
        private String itemID = "unknown";
        // 折扣
        private double discountCode = 1.0;
        private int numItems = 0;
        
        public double getDiscountCode() {
            return discountCode;
        }
        
        public void setDiscountCode(double discountCode) {
            this.discountCode = discountCode;
        }
        
        public String getItemID() {
            return itemID;
        }
        
        public void setItemID(String itemID) {
            this.itemID = itemID;
        }
        
        public int getNumItems() {
            return numItems;
        }
        
        public void setNumItems(int numItems) {
            this.numItems = numItems;
        }
        
        // 获取单价
        public double getItemCost() {
            double cost;
            if("a1234".equals(itemID)) {
                cost = 12.99 * getDiscountCode();
            } else {
                cost = -99;
            }
            return roundToPennies(cost);
        }
        
        // 计算到分位
        public double roundToPennies(double cost) {
            return (Math.floor(cost * 100) / 100.0);
        }
        
        // 计算总价格
        public double getTotalCost() {
            return (getItemCost() * getNumItems());
        }
        
    }




    -------------------------------------------------------------------------------------------------------------------------------------


    12.HTML页面输入内容,提交给JSP文件,JSP将这些内容存入JavaBean,再从JavaBean中拿出来显示。
    中间有个中文乱码的处理问题。


    ①SayHelloBean.html


    <html>
        <head>
            <title>数据输入</title>
            <meta http-equiv="Content-Type" content="text/html;charset=gb2312">
        </head>
        
        <body bgcolor="#FFFFFF">
            <div align="center" >
                <p>请输入数据</p>
                    <form method="post" action="SayHelloBean.jsp" >
                        <p>姓名
                            <input type="text" name="name">
                            性别
                            <select name="sex">
                                <option value="先生">先生</option>
                                <option value="女士">女士</option>
                            </select>
                        </p>
                        <p>
                            <input type="submit" name="Submit" value="提交">
                        </p>
                    </form>
                    <p>&nbsp;</p>
                    <p>&nbsp;</p>
            </div>
        </body>
    </html>




    ②SayHelloBean.jsp


    <%@page language="java" import="bean.HelloBean;" %>
    <%@page contentType="text/html;charset=gb2312" %>


    <%--先将传过来的request中的字符编码格式设置成gbk,再取内容--%>
    <% request.setCharacterEncoding("gbk"); %>


    <jsp:useBean id="hello" class="bean.HelloBean" scope="request" >
        <%--通过*来设置所有属性和输入参数之间的关联,struts中大量运用--%>
            <jsp:setProperty name="hello" property="*" />
    </jsp:useBean>
        
    <html>
        <head>
            <title>HelloBean</title>
            <meta http-equiv="Content-Type" content="text/html;charset=gb2312">
        </head>
        
        <body bgcolor="#FFFFFF">
            <p>&nbsp;</p>
            <p align="center" >
                <font size="4">欢迎
                    <font color="#0000FF">
                        <b>
                            <%--转码(终结解决方案):将hello对象中name属性的值用ISO8859_1编码格式以字节数组拿出,再转化成gbk格式---%>
                            <%--= new String(hello.getName().getBytes("ISO8859_1"),"gbk")--%>
                        </b>
                    </font>
                    <%--转码(终结解决方案):将hello对象中sex属性的值用ISO8859_1编码格式以字节数组拿出,再转化成gbk格式---%>
                    <%--= new String(hello.getSex().getBytes("ISO8859_1"),"gbk")--%>
                </font>
            </p>
            <jsp:getProperty name="hello" property="name" />
            <jsp:getProperty name="hello" property="sex" />
        </body>
    </html>




    ③HelloBean.java


    package bean;


    public class HelloBean {


        private String name = "";
        private String sex = "";
        
        public HelloBean() {}
        
        public String getName() {
            return name;
        }
        
        public void setName(String name) {
            this.name = name;
        }
        
        public String getSex() {
            return sex;
        }
        
        public void setSex(String sex) {
            this.sex = sex;
        }
        
    }
  • 相关阅读:
    所有程序员都是自学成才
    Xcode6模拟器路径
    Xcode7中模拟器的位置
    数据结构中的二级指针和引用
    02_线性表的链式表示和实现
    Spring 单例 httprequest 线程安全
    Springboot listener
    Spring单例 和 Scope注解
    红黑树
    线程池
  • 原文地址:https://www.cnblogs.com/anyuan9/p/6171566.html
Copyright © 2011-2022 走看看