一、JSP引言

  JSP全名为Java Server Pages,中文名叫java服务器页面,其根本是一个简化的Servlet设计。它是在传统的网页HTML文件(*.htm,*.html)中插入Java程序段(Scriptlet)和JSP标记(tag),从而形成JSP文件,后缀名为(*.jsp)。 用JSP开发的Web应用是跨平台的,既能在Linux下运行,也能在其他操作系统上运行。

  作用:替代在java web开发中负责显得的Servlet。

二、jsp编程语法

  1、脚本

    a、输出脚本(表达式脚本)

      作用:用于把java表达式的结果,输出到页面中。

      语法:<%=java表达式%>

    b、声明脚本

      作用:用于声明(定义)变量或者函数。

      语法:<%!java语法  声明变量或者函数%>

      注意:声明脚本中声明的内容,只能用于输出脚本或者普通脚本。

    c、普通脚本

      作用:可以应用一切的java语法,除了定义函数。

      语法:<% java语法 %>

    注意:脚本与脚本、脚本与html标签是不能嵌套的。

  2、指令

    a、page

      <%@page  attribute1=value1 attrubute2=value2%>

      (1)language="java"

      (2)contentType="text/html;charset=UTF-8"

        其中的charset=UTF-8,表示的是服务器相应client浏览器的编码方式。

      (3)pageEncoding="UTF-8"

        这个代表的是jsp转换成java源文件的字符集编码。

      (4)import="包1,包2"

      (5)session="true|false"

        true(默认):如果当前没有创建session,则创建session,有session的话,直接使用该session。

        false:如果当前有session,则使用该session,如果没有,则不应用session。

      (6)isElIgnored="true|false"

        true:忽略EL表达式。

        false(默认):不忽略EL表达式。

      (7)errorPage

        指定当发生错误时,跳转到该页面。

      (8)isErrorPage

        指定当前页面是否为错误页面

    b、include

      静态包含,源代码包含,将不同的jsp页面整合到同一个页面中。

      不建议在开发中使用,风险多。

    c、taglib

      作用:引入jsp中的标签库

      <%@taglib uri="" prefix="">

  3、动作

    a、include

      动态包含,输出包含,推荐使用这种包含,代码没有入侵性。

    b、forward

      jsp之间的跳转(没有任何意义)

  4、内置对象

    在jsp中的输出脚本,或者普通脚本中,不用创建便可以直接使用的java对象。

    a、request

      相关操作:

        request.setAttribute();

        request.getAttribute();

        request.getContextPath();  //用于动态获取应用名

    b、response(不怎么用)

    c、session

      相关操作:

        session.setAttribute();

        session.getAttribute();

    d、application(ServletContext作用域)

    e、out

      用于页面输出,等价于<%= %>

    f、config(ServletConfig)

    g、exception

      这个内置对象只能使用在声明isErrorPage的jsp页面中,代表上一张发生错误的页面产生的异常。

    h、page

      代表当前的jsp页面,类似于this。

    i、pageContext

      (1)pageContext可以获得其他的8种内置对象

        pageContext.getRequest();

        pageContext.getResponse();

        pageContext.getOut();

        ....

      (2)pageContext是一个作用域(request,session,application)

        pageConetxt在本页面有效。

        pageContext.setAttribute();

        pageContext.getAttribute();

      (3)pageContext可以操作设置其他的作用域

        pageContext.setAttribute("key","value",PageContext.REQUEST_SCOPE);

        pageContext.getAttribute("key",PageConetxt.REQUEST_SCOPE);

        ...

        

  

浅谈JSP(一)的更多相关文章

  1. 【sql注入】浅谈JSP安全开发之SQL注入

    [sql注入]浅谈JSP安全开发之SQL注入 本文转自:i春秋社区 前言不管是用什么语言编写WEB应用程序,他们都或多或少有一些地方存在漏洞.如果你想知道漏洞的运行原理,和防御方案,那么请看完本篇文章 ...

  2. 浅谈JSP中include指令与include动作标识的区别

    JSP中主要包含三大指令,分别是page,include,taglib.本篇主要提及include指令. include指令使用格式:<%@ include file="文件的绝对路径 ...

  3. 浅谈JSP注释

    HTML注释 JSP文件是由HTML尿急和嵌入的Java程序片段组成的,所以在HTML中的注释同样可以在JSP文件中使用.注释格式:<!--注释内容--> <!-- 欢迎提示信息! ...

  4. 浅谈JSP(二)

    一.EL表达式 作用:从作用域(pageContext,request,session,application)中取值,并显示在页面中. 本质:用于替换输出脚本(<%= %>). 1.从作 ...

  5. 【The Most Important】浅谈JSP表单Post方式中文乱码问题

    首先祝大家鸡年吉祥!在这里我要说下这两天里这个问题困扰着我,大过年的心情都被烦扰的不好了,所以我带着兴奋的心情来赶快完成这篇博客,解决大家的问题.我的问题是post方式传递表单数据,Tomcat服务器 ...

  6. 浅谈 JSP & Servlet

    body { text-align: center; } div.develon { background-color: #cccccc; font-size: 20px; } 背景 相信大家都见过这 ...

  7. 【安全开发】浅谈JSP安全开发之XSS

    前言     大家好,好男人就是我,我就是好男人,我就是-0nise.在各大漏洞举报平台,我们时常会看到XSS漏洞.那么问题来了,为何会出现这种漏洞?出现这种漏洞应该怎么修复?目录     1.XSS ...

  8. jsp内置对象浅谈

    jsp内置对象浅谈 | 浏览:1184 | 更新:2013-12-11 16:01 JSP内置对象:我们在使用JSP进行页面编程时可以直接使用而不需自己创建的一些Web容器已为用户创建好的JSP内置对 ...

  9. 浅谈struts2之chain

    转自:http://blog.csdn.net/randomnet/article/details/8656759 前一段时间,有关chain的机制着实困绕了许久.尽管网上有许多关于chain的解说, ...

随机推荐

  1. MiniSD卡是什么

    Mini SD卡比目前主流的普通SD卡(如DC或DV上使用的SD卡),在外形上更加小巧,重量仅有3克左右,体积只有21.5x20x1.4mm,比普通SD卡足足节省了60%的空间.别小看这么小的外形,它 ...

  2. Android 获取屏幕分辨率

    原文:Android 获取屏幕分辨率 得到一个屏幕尺寸的三种方法如下:        // 通过WindowManager获取        DisplayMetrics dm = new Displ ...

  3. [置顶] ProcessOn:划时代性的在线作图工具

    ProcessOn是一款专业作图人员的社交网络,这里汇聚很多业界专家.学者,同时他们分享的作品又形成一个庞大的知识图库,你在学习专业知识的同时还可以结交一些志同道合的新朋友. ProcessOn核心设 ...

  4. 什么是xss盲打

    什么是xss盲打? 盲打仅仅是一种惯称的说法,就是不知道后台不知道有没有xss存在的情况下,不顾一切的输入xss代码在留言啊,feedback啊之类的地方,尽可能多的尝试xss的语句与语句的存在方式, ...

  5. Cocos2d-x 3.1.1 学习日志6--30分钟了解C++11新特性

    新的keyword auto C++11中引入auto第一种作用是为了自己主动类型推导 auto的自己主动类型推导,用于从初始化表达式中判断出变量的数据类型.通过auto的自己主动类型推导.能够大大简 ...

  6. printf("%d, %d\n", i++, ++i)的输出结果是确定的吗???

    1. 问题描述 以下代码的输出结果是什么? 题目1: ; printf("%d, %d\n", i++, ++i); 题目2: ; printf("%d, %d, %d, ...

  7. Ado.net 类扩展属性

    .要扩展的类名字一样,2个类加(partial) 小例子: using System; using System.Collections.Generic; using System.Linq; usi ...

  8. 升级python的sqlite库版本

    今天了解了一下用python获取chrome cookie信息,在研究的过程中,发现打开数据库失败,后来调查了一下发现是由于sqlite3库太老的缘故,起码需要3.8以上,然后看了一下python 2 ...

  9. nginx proxy_pass 后面的斜杠

    # add / location /app/ { proxy_pass http://$backend/; } # location /app/ { proxy_pass http://$backen ...

  10. php 解析xml 的四种方法(转)

    XML处理是开发过程中经常遇到的,PHP对其也有很丰富的支持,本文只是对其中某几种解析技术做简要说明,包括:Xml parser, SimpleXML, XMLReader, DOMDocument. ...