- SpringMVC @RequestHeader @CookieValue 处理获取请求参数的乱码问题
杨宸杨
SpringMVCjavajvm数据库
SpringMVC@RequestHeader@CookieValue处理获取请求参数的乱码问题@RequestHeader@CookieValue什么是cookie通过POJO获取请求参数通过CharacterEncodingFilter处理获取请求参数的乱码问题get请求的乱码post请求乱码处理获取请求参数的乱码问题)@RequestHeader1.@RequestHeader是将请求头信息
- 代码随想录算法训练营第六十四天| 图论09
Rachela_z
算法图论
dijkstra(堆优化版)精讲代码随想录importheapqclassEdge:def__init__(self,to,val):self.to=toself.val=valdefdijkstra(n,m,edges,start,end):grid=[[]for_inrange(n+1)]forp1,p2,valinedges:grid[p1].append(Edge(p2,val))minD
- 算法——图论——交通枢纽
阿饼240
算法c++动态规划图论
原题#include#include#includeusingnamespacestd;typedefpairPII;vectorgraph[100];vector>Dist(100,vector(100,-1));vectorState(100,false);voidDijkstra(ints,intn){for(inti=0;i,greater>pq;pq.emplace(0,s);while
- Dijkstra算法例题及解析
_gxd_
算法
最短路算法(2)——Dijkstra算法本章一共有三道例题。1.最短路2.TiltheCowsComeHome3.成语接龙1.最短路Description在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt。但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以现在他们想要寻找最短的从商店到赛场的路线,你可以帮助他们吗?FormatInput输入包括多组数据
- @Component—@Autowired—@Mapper—@Bean
追JAVA的小菜鸟
零碎知识点beanjavamybatisspringcomponent
注解详解一、@Component二、@Autowired注解支持context:annotation-config——手动注入beancontext:component-scanbase-package="zy.pojo"——扫描包并自动注入总结三、@Mapper@Mapper与@Repository四、@Bean@Bean与@Component区别一、@Component作用:表明了此类为一个组
- 什么是Mybatis?最全的Mybatis知识点整合!
Tyloo_wdnmd
数据库mybatisjavapythonmysql
什么是Mybatis?最全的Mybatis知识点整合!一、什么是Mybatis?MyBatis是一个半ORM(对象关系映射)框架,它内部封装了JDBC,开发时只需要关注SQL语句本身,不需要花费精力去加载驱动、创建连接、创建Statement等繁杂过程。程序员直接编写原生态sql,可以严格控制sql执行性能,灵活度高。Mybatis可以使用XML或注解来配置和映射原生信息,将POJO映射成数据库中
- MyBatis高级查询:一对多查询详解
蓝天资源分享
mybatistomcatjava
MyBatis高级查询:一对多查询详解MyBatis是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。MyBatis免除了几乎所有的JDBC代码和手动设置参数以及获取结果集的工作。MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJOs(PlainOldJavaObjects,普通的Java对象)映射成数据库中的记录。本文将深入探讨MyBatis中的
- python 实现 A* 算法
dev.null
Pythonpython算法开发语言
A*算法是一种广泛使用的路径搜索算法,结合了启发式搜索和Dijkstra算法的优点。它通过评估每个节点的代价函数(f(n)=g(n)+h(n))来选择最优路径,其中:(g(n))是从起点到当前节点的实际代价。(h(n))是从当前节点到目标节点的启发式估计代价(如曼哈顿距离或欧几里得距离)。以下是一个Python实现的A*算法示例:Python实现A*算法importheapqfrommathimp
- PO、DTO、VO等9大对象划分详解,让你的代码不再“一团糟”
码熔burning
SpringBootJavaJavaSpringBoot
目录一、PO(PersistentObject)二、DO(DomainObject)三、TO(TransferObject)四、DTO(DataTransferObject)五、VO(ViewObject)六、BO(BusinessObject)七、POJO(PlainOrdinaryJavaObject)八、DAO(DataAccessObject)九、Entity对象转换与使用场景总结何时使用
- 手写一些常见算法
林tong学
算法排序算法java数据结构
手写一些常见算法快速排序归并排序Dijkstra自定义排序交替打印0和1冒泡排序插入排序堆排序快速排序publicclassMain{publicstaticvoidmain(String[]args){intnums[]={1,3,2,5,4,6,8,7,9};quickSort(nums,0,nums.length-1);}privatestaticvoidquickSort(int[]num
- 美年旅游总结 1
pedestrian_h
springjava后端
美年旅游总结1环境搭建1,项目整体结构2,关系3,导入环境依赖1,meinian_parentpom4.0.0cn.guojava.zookerper_dubbomeinianpom1.0-SNAPSHOTmeinian_commonmeinian_pojomeinian_daomeinian_interfacemeinian_servicemeinian_web4.125.0.5.RELEASE
- POJ 2227 The Wedding Juicer(优先队列+BFS)
幼儿园大哥~
数据结构算法
传送门题目大意一个矩形区域,高低起伏,求最多储水量。(边界不能储水)思路先将边界加入优先队列,每次取高度最小的点,找与其相邻且未访问过的点,若邻点高度大于等于它,直接加入优先队列更新边界,否则更新答案,并将邻点的高度置为该点高度,然后加入优先队列更新边界。代码structnode{intx;inty;llh;booloperatorX.h;}};intn,m;lla[500][500];intvi
- POJ-2227 The Wedding Juicer(NYOJ-547 Interesting Punch-Bowl)
weixin_30802171
TheWeddingJuicerTimeLimit:2000MSMemoryLimit:65536KTotalSubmissions:2803Accepted:1225DescriptionFarmerJohn'scowshavetakenasidejobdesigninginterestingpunch-bowldesigns.Thedesignsarecreatedasfollows:*Afl
- POJ 2227 -- The Wedding Juicer(bfs+优先队列)
Ac-try
队列/优先队列搜索
题目大意:一个W*H的网格,每个单位格的高度不一样,往这个网格注水,问能储存多少水;思路分析:四周不能注水,和木桶原理一样,要以最低的高度作为能储水的高度,否则水就会溢出;将网格最外层的点开始加入队列,每次去高度最小的点作为“木桶”最低边,看其连接的点,如果高度大于自己加入队列,否则注水至自己的高度加入队列。代码实现:#include#include#includeusingnamespacest
- Apple Tree POJ - 3321
里欧布鲁斯
算法
对树进行DFS,记时间节点cnt初始等于0,每到一个新的节点(之前没有到过的节点),将cnt+1,作为这个节点的开始时刻,等到遍历完以这个节点为根的子树,回到这个节点时,此时的cnt是这个节点的结束时刻,例如下图:这样就实现了,将节点与节点之间的包含关系,转化到了线段区间上#include#include#include#includeusingnamespacestd;#definelowbit
- The Wedding Juicer POJ - 2227
里欧布鲁斯
算法
采取从外层边界,一步一步向内部拓展的策略,具体来说,一开始将最外面一层的点加入队列,并标记这些点的坐标已经被访问取出队列中高度最低的点,将其弹出,查看其上下左右的点,如果新点没有被访问过,分两种情况:1.如果新点的高度大于等于当前点:将新点加入队列,标记新点已经访问过了,该点无法储水2.如果新点的高度小于当前点:则新点储水(当前点的高度-新点的高度),首先,这么多水一定可以存,因为当前点的高度是边
- MyBatis-Plus 与 Redis
#sakura
mybatisredis数据库
1MyBatis-Plus1.1MyBatis-Plus简介MyBatis是一款优秀的持久层框架,它能将接口和JavaPOJO(PlainOldJavaObjects,普通Java对象)映射为数据库中的数据。支持自定义SQL、存储过程,功能强大。MyBatis承担了几乎所有的JDBC代码,包括设置参数和获取结果等工作,可通过简单的XML或注解进行配置。MyBatis-Plus是MyBatis的最佳
- P10948 升降梯上 灰 题解
M_CI_
算法
Part0.前言没想到SPFA-SLF冲进了最优解第一版,比多数Dijkstra还快。评测记录(SPFA-SLF43ms)评测记录(Dijkstra44ms)Part1.题意简述有MMM个移动系数−Nusingnamespacestd;#defineintlonglong#definepiipair#definefifirst#definesesecondintn,m,s,c[30],dis[10
- 抖音采集工具Gui版:高效无水印下载抖音视频的神器
东风西巷
音视频软件需求
抖音采集工具Gui版是一款由52pojie论坛的@biqiang大神自制的功能强大的采集工具。它专为抖音视频下载设计,能够帮助用户轻松获取抖音平台上的各种视频资源,支持批量下载,极大地提升了下载效率。全面的资源采集支持采集抖音作品、Webp动态封面、短剧、喜欢、话题、音乐等多种内容。无论是热门视频还是小众作品,都能轻松下载。批量下载与高效管理用户可以批量下载指定作者的所有作品、单个视频、某话题下的
- 项目笔记——RPC框架
NUAA庞
其他
文章目录RPC知识流程图什么是RPC为什么用RPC,不用HTTP(拓展)技术栈流程服务注册意义/场景test服务的POJO类服务信息服务实例注册模块主体注册到注册中心注册中心注销场景注销的钩子函数及前置注册中心注销远程调用意义定义接口test重写jdk动态代理的invoke拓展服务发现负载均衡知识使用网络传输netty知识POJO类netty心跳场景及简介串联其它模块消费端生产端业务处理场景实现粘
- 【数学建模技术】路径规划算法-Dijkstra算法
一键难忘
数学建模技术超入门Dijkstra数学建模算法路径规划算法
路径规划算法-Dijkstra算法1.引言路径规划是许多领域中的核心问题,尤其是在机器人导航、地理信息系统(GIS)、交通管理等方面。路径规划算法的主要目标是寻找从起点到终点的最短路径。Dijkstra算法作为一种经典的单源最短路径算法,广泛应用于各种实际问题中。本篇文章将详细探讨Dijkstra算法的原理、应用场景,并通过代码实例进行深入解析。2.Dijkstra算法原理Dijkstra算法是由
- 【路径规划】基于A算法和Dijkstra算法的路径规划附Python代码
天天Matlab科研工作室
无人机matlab仿真电子资源算法python开发语言
✅作者简介:热爱科研的Matlab仿真开发者,擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。往期回顾关注个人主页:Matlab科研工作室个人信条:格物致知,完整Matlab代码及仿真咨询内容私信。内容介绍路径规划作为人工智能和机器人技术领域的核心问题之一,在导航、交通运输、游戏开发等领域有着广泛的应用。解决路径规划问题,旨在找到一条从起始点到目标点,并满足特定约束条件(如最短
- 【Flink银行反欺诈系统设计方案】4.Flink CEP 规则表刷新方式
*星星之火*
Flink反欺诈flinkjava数据库
【Flink银行反欺诈系统设计方案】4.FlinkCEP规则表刷新方式概要1.**实现思路**2.**代码实现**2.1定义POJO2.2规则加载与动态更新2.3动态规则更新与CEP模式匹配3.**规则更新的触发机制**3.1定期加载规则3.2监听规则变化4.**总结**概要在FlinkCEP中,规则的动态更新是一个关键需求,尤其是在风控系统中,规则可能会频繁调整。为了实现规则的动态更新,我们可以
- 【智能算法】Dijkstra算法
大雨淅淅
智能算法算法python机器学习大数据图论
目录一、Dijkstra算法概述1.1基本概念1.2算法思想1.3算法步骤1.4算法特点二、Dijkstra算法优缺点和改进2.1Dijkstra算法优点2.2Dijkstra算法缺点2.3Dijkstra算法改进三、Dijkstra算法编程实现3.1Dijkstra算法C语言实现3.2Dijkstra算法JAVA实现3.3Dijkstra算法python实现3.4Dijkstra算法matlab
- 【路径规划】二维Dijkstra启发式改进算法
神精兵院院长
Python算法算法python动态规划
我们使用了A*算法的启发式(曼哈顿距离)来改进Dijkstra算法的性能。当我们将邻居节点添加到优先队列时,我们使用了distance+heuristic作为优先级,这样我们可以更快地找到通往目标节点的路径。importheapqimportnumpyasnpdefheuristic(a,b):(x1,y1)=a(x2,y2)=breturnabs(x1-x2)+abs(y1-y2)#使用曼哈顿距
- 关于网络数通工程师 OSPF 协议的常见面试问题
他不爱吃香菜
网络面试解答网络协议网络服务器php面试运维网络协议
基础理论部分OSPF是什么?其核心设计目标及主要特性有哪些?OSPF(开放式最短路径优先)是基于链路状态的内部网关协议(IGP),使用Dijkstra的SPF算法计算最短路径树,核心目标包括快速收敛、分层网络设计(区域划分)和避免路由环路12。主要特性:支持VLSM/CIDR,适用于复杂IP规划12。通过组播(224.0.0.5/224.0.0.6)传递协议报文,减少广播流量13。
- 算法分析-贪心算法
old-handsome
算法贪心算法算法
文章目录前言一、定义二、特点三、使用场景适用场景:何时使用部分背包问题活动安排问题最优装载问题最小生成树Prim算法:按点检索,适用于稠密图Kruskal算法:并查集+最小生成树Dijkstra算法:不能存在负权边,松弛操作总结前言本博客仅做学习笔记,如有侵权,联系后即刻更改科普:贪心算法一、定义贪心算法是指在对问题进行求解时,在每一步选择中都采取最好或者最优(最有利)的选择,从而希望最终结果是最
- 银行家算法
重岳
算法java
银行家算法(Banker'sAlgorithm)是由计算机科学家EdsgerDijkstra提出的,是一种用于处理资源分配和避免死锁的算法。它是一个安全的资源分配算法,确保在多进程共享系统资源时能够保持系统处于安全状态。银行家算法的核心目标是:在动态分配资源的过程中,判断是否存在一个安全的执行顺序,确保系统在执行过程中不会进入死锁状态。可以看作是一种预防死锁的策略。核心概念安全状态(SafeSta
- 华为OD机试 - 寻找最优的路测线路 - Dijkstra算法(Python/JS/C/C++ 2024 E卷 200分)
哪 吒
华为od算法pythonDijkstra
华为OD机试2024E卷题库疯狂收录中,刷题点这里专栏导读本专栏收录于《华为OD机试真题(Python/JS/C/C++)》。刷的越多,抽中的概率越大,私信哪吒,备注华为OD,加入华为OD刷题交流群,每一题都有详细的答题思路、详细的代码注释、3个测试用例、为什么这道题采用XX算法、XX算法的适用场景,发现新题目,随时更新,全天CSDN在线答疑。一、题目描述评估一个网络的信号质量Q,其中一个做法是将
- 单源最短路径
陵易居士
数据结构与算法算法图论
目录无负权单源最短路径迪杰斯特拉算法(dijkstra)朴素版迪杰斯特拉小根堆优化版本dijkstra有负权的图的单源最短路径SPFA总结无负权单源最短路径在处理图论相关问题时,经常会遇到求一点到其他点的最短距离是多少的问题,很多实际应用场景的题目也可以转化成求最短路的问题,这里我们先来了解没有负权的图的最短路问题.迪杰斯特拉算法(dijkstra)迪杰斯特拉算法是由dijkstra提出的,它的主
- java杨辉三角
3213213333332132
java基础
package com.algorithm;
/**
* @Description 杨辉三角
* @author FuJianyong
* 2015-1-22上午10:10:59
*/
public class YangHui {
public static void main(String[] args) {
//初始化二维数组长度
int[][] y
- 《大话重构》之大布局的辛酸历史
白糖_
重构
《大话重构》中提到“大布局你伤不起”,如果企图重构一个陈旧的大型系统是有非常大的风险,重构不是想象中那么简单。我目前所在公司正好对产品做了一次“大布局重构”,下面我就分享这个“大布局”项目经验给大家。
背景
公司专注于企业级管理产品软件,企业有大中小之分,在2000年初公司用JSP/Servlet开发了一套针对中
- 电驴链接在线视频播放源码
dubinwei
源码电驴播放器视频ed2k
本项目是个搜索电驴(ed2k)链接的应用,借助于磁力视频播放器(官网:
http://loveandroid.duapp.com/ 开放平台),可以实现在线播放视频,也可以用迅雷或者其他下载工具下载。
项目源码:
http://git.oschina.net/svo/Emule,动态更新。也可从附件中下载。
项目源码依赖于两个库项目,库项目一链接:
http://git.oschina.
- Javascript中函数的toString()方法
周凡杨
JavaScriptjstoStringfunctionobject
简述
The toString() method returns a string representing the source code of the function.
简译之,Javascript的toString()方法返回一个代表函数源代码的字符串。
句法
function.
- struts处理自定义异常
g21121
struts
很多时候我们会用到自定义异常来表示特定的错误情况,自定义异常比较简单,只要分清是运行时异常还是非运行时异常即可,运行时异常不需要捕获,继承自RuntimeException,是由容器自己抛出,例如空指针异常。
非运行时异常继承自Exception,在抛出后需要捕获,例如文件未找到异常。
此处我们用的是非运行时异常,首先定义一个异常LoginException:
/**
* 类描述:登录相
- Linux中find常见用法示例
510888780
linux
Linux中find常见用法示例
·find path -option [ -print ] [ -exec -ok command ] {} \;
find命令的参数;
- SpringMVC的各种参数绑定方式
Harry642
springMVC绑定表单
1. 基本数据类型(以int为例,其他类似):
Controller代码:
@RequestMapping("saysth.do")
public void test(int count) {
}
表单代码:
<form action="saysth.do" method="post&q
- Java 获取Oracle ROWID
aijuans
javaoracle
A ROWID is an identification tag unique for each row of an Oracle Database table. The ROWID can be thought of as a virtual column, containing the ID for each row.
The oracle.sql.ROWID class i
- java获取方法的参数名
antlove
javajdkparametermethodreflect
reflect.ClassInformationUtil.java
package reflect;
import javassist.ClassPool;
import javassist.CtClass;
import javassist.CtMethod;
import javassist.Modifier;
import javassist.bytecode.CodeAtt
- JAVA正则表达式匹配 查找 替换 提取操作
百合不是茶
java正则表达式替换提取查找
正则表达式的查找;主要是用到String类中的split();
String str;
str.split();方法中传入按照什么规则截取,返回一个String数组
常见的截取规则:
str.split("\\.")按照.来截取
str.
- Java中equals()与hashCode()方法详解
bijian1013
javasetequals()hashCode()
一.equals()方法详解
equals()方法在object类中定义如下:
public boolean equals(Object obj) {
return (this == obj);
}
很明显是对两个对象的地址值进行的比较(即比较引用是否相同)。但是我们知道,String 、Math、I
- 精通Oracle10编程SQL(4)使用SQL语句
bijian1013
oracle数据库plsql
--工资级别表
create table SALGRADE
(
GRADE NUMBER(10),
LOSAL NUMBER(10,2),
HISAL NUMBER(10,2)
)
insert into SALGRADE values(1,0,100);
insert into SALGRADE values(2,100,200);
inser
- 【Nginx二】Nginx作为静态文件HTTP服务器
bit1129
HTTP服务器
Nginx作为静态文件HTTP服务器
在本地系统中创建/data/www目录,存放html文件(包括index.html)
创建/data/images目录,存放imags图片
在主配置文件中添加http指令
http {
server {
listen 80;
server_name
- kafka获得最新partition offset
blackproof
kafkapartitionoffset最新
kafka获得partition下标,需要用到kafka的simpleconsumer
import java.util.ArrayList;
import java.util.Collections;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.
- centos 7安装docker两种方式
ronin47
第一种是采用yum 方式
yum install -y docker
 
- java-60-在O(1)时间删除链表结点
bylijinnan
java
public class DeleteNode_O1_Time {
/**
* Q 60 在O(1)时间删除链表结点
* 给定链表的头指针和一个结点指针(!!),在O(1)时间删除该结点
*
* Assume the list is:
* head->...->nodeToDelete->mNode->nNode->..
- nginx利用proxy_cache来缓存文件
cfyme
cache
user zhangy users;
worker_processes 10;
error_log /var/vlogs/nginx_error.log crit;
pid /var/vlogs/nginx.pid;
#Specifies the value for ma
- [JWFD开源工作流]JWFD嵌入式语法分析器负号的使用问题
comsci
嵌入式
假如我们需要用JWFD的语法分析模块定义一个带负号的方程式,直接在方程式之前添加负号是不正确的,而必须这样做:
string str01 = "a=3.14;b=2.71;c=0;c-((a*a)+(b*b))"
定义一个0整数c,然后用这个整数c去
- 如何集成支付宝官方文档
dai_lm
android
官方文档下载地址
https://b.alipay.com/order/productDetail.htm?productId=2012120700377310&tabId=4#ps-tabinfo-hash
集成的必要条件
1. 需要有自己的Server接收支付宝的消息
2. 需要先制作app,然后提交支付宝审核,通过后才能集成
调试的时候估计会真的扣款,请注意
- 应该在什么时候使用Hadoop
datamachine
hadoop
原帖地址:http://blog.chinaunix.net/uid-301743-id-3925358.html
存档,某些观点与我不谋而合,过度技术化不可取,且hadoop并非万能。
--------------------------------------------万能的分割线--------------------------------
有人问我,“你在大数据和Hado
- 在GridView中对于有外键的字段使用关联模型进行搜索和排序
dcj3sjt126com
yii
在GridView中使用关联模型进行搜索和排序
首先我们有两个模型它们直接有关联:
class Author extends CActiveRecord {
...
}
class Post extends CActiveRecord {
...
function relations() {
return array(
'
- 使用NSString 的格式化大全
dcj3sjt126com
Objective-C
格式定义The format specifiers supported by the NSString formatting methods and CFString formatting functions follow the IEEE printf specification; the specifiers are summarized in Table 1. Note that you c
- 使用activeX插件对象object滚动有重影
蕃薯耀
activeX插件滚动有重影
使用activeX插件对象object滚动有重影 <object style="width:0;" id="abc" classid="CLSID:D3E3970F-2927-9680-BBB4-5D0889909DF6" codebase="activex/OAX339.CAB#
- SpringMVC4零配置
hanqunfeng
springmvc4
基于Servlet3.0规范和SpringMVC4注解式配置方式,实现零xml配置,弄了个小demo,供交流讨论。
项目说明如下:
1.db.sql是项目中用到的表,数据库使用的是oracle11g
2.该项目使用mvn进行管理,私服为自搭建nexus,项目只用到一个第三方 jar,就是oracle的驱动;
3.默认项目为零配置启动,如果需要更改启动方式,请
- 《开源框架那点事儿16》:缓存相关代码的演变
j2eetop
开源框架
问题引入
上次我参与某个大型项目的优化工作,由于系统要求有比较高的TPS,因此就免不了要使用缓冲。
该项目中用的缓冲比较多,有MemCache,有Redis,有的还需要提供二级缓冲,也就是说应用服务器这层也可以设置一些缓冲。
当然去看相关实现代代码的时候,大致是下面的样子。
[java]
view plain
copy
print
?
public vo
- AngularJS浅析
kvhur
JavaScript
概念
AngularJS is a structural framework for dynamic web apps.
了解更多详情请见原文链接:http://www.gbtags.com/gb/share/5726.htm
Directive
扩展html,给html添加声明语句,以便实现自己的需求。对于页面中html元素以ng为前缀的属性名称,ng是angular的命名空间
- 架构师之jdk的bug排查(一)---------------split的点号陷阱
nannan408
split
1.前言.
jdk1.6的lang包的split方法是有bug的,它不能有效识别A.b.c这种类型,导致截取长度始终是0.而对于其他字符,则无此问题.不知道官方有没有修复这个bug.
2.代码
String[] paths = "object.object2.prop11".split("'");
System.ou
- 如何对10亿数据量级的mongoDB作高效的全表扫描
quentinXXZ
mongodb
本文链接:
http://quentinXXZ.iteye.com/blog/2149440
一、正常情况下,不应该有这种需求
首先,大家应该有个概念,标题中的这个问题,在大多情况下是一个伪命题,不应该被提出来。要知道,对于一般较大数据量的数据库,全表查询,这种操作一般情况下是不应该出现的,在做正常查询的时候,如果是范围查询,你至少应该要加上limit。
说一下,
- C语言算法之水仙花数
qiufeihu
c算法
/**
* 水仙花数
*/
#include <stdio.h>
#define N 10
int main()
{
int x,y,z;
for(x=1;x<=N;x++)
for(y=0;y<=N;y++)
for(z=0;z<=N;z++)
if(x*100+y*10+z == x*x*x
- JSP指令
wyzuomumu
jsp
jsp指令的一般语法格式: <%@ 指令名 属性 =”值 ” %>
常用的三种指令: page,include,taglib
page指令语法形式: <%@ page 属性 1=”值 1” 属性 2=”值 2”%>
include指令语法形式: <%@include file=”relative url”%> (jsp可以通过 include