- net.sf.jsqlparser.statement.select.Select.getSelectBody()
m0_74824002
面试学习路线阿里巴巴java
1、问题原因发生这个问题就是因为Pagehelper中jsqlparser和Mybatis-puls中jsqlparser冲突,以我的项目来说,我项目中的Pagehelper中jsqlparser版本为4.2而Mybatis-puls中jsqlparser的版本为4.9,就导致版本兼容问题2、解决方法如果你想以Pagehelper中jsqlparser的版本来使用的话,那么项目将启动不起来,就比如
- C++Primer学习(5.4和5.5 迭代语句和跳转语句)
黑果果的思考
零基础学习C++c++
5.4迭代语句迭代语句通常称为循环,它重复执行操作直到满足某个条件才停下来。while和for语句在执行循环体之前检查条件,dowhile语句先执行循环体,然后再检查条件。5.4.1while语句只要条件为真,while语句(whilestatement)就重复地执行循环体,它的语法形式是while(condition)statement;在while结构中,只要condition的求值结果为真就
- C++Primer学习(5.3条件语句)
黑果果的思考
零基础学习C++c++学习
5.3条件语句C++语言提供了两种按条件执行的语句。一种是if语句,它根据条件决定控制流:另外一种是switch语句,它计算一个整型表达式的值,然后根据这个值从几条执行路径中选择一条。5.3.1if语句if语句(ifstatement)的作用是:判断一个指定的条件是否为真,根据判断结果决定是否执行另外一条语句。if语句包括两种形式:一种含有else分支,另外一种没有。简单if语句的语法形式是if(
- C++Primer学习(5.1和5.2 简单语句和语句作用域)
黑果果的思考
零基础学习C++c++学习
通常情况下,语句是顺序执行的。但除非是最简单的程序,否则仅有顺序执行远远不够。因此,C++语言提供了一组控制流(fow-of-control)语句以支持更复杂的执行路径。5.1简单语句C++语言中的大多数语句都以分号结束,一个表达式,比如iva1+5,末尾加上分号就变成了表达式语句(expressionstatement)。表达式语句的作用是执行表达式并丢弃掉求值结果:ival+5;//一条没什么
- Mybatis xml 无法正常解析 Invalid bound statement
javaspringboot
问题背景使用插件mybatisX生成的mapper.xml没有办法被正常解析,项目使用的是nacos作为配置中心;问题定位首先看了一下网上说的常见几种问题,比如id不匹配,或者说pom里缺少resource配置导致target里没有xml;这些都没有出现;那接下来就只能从源码出发解决问题;通过报错的堆栈信息我发现问题的出发点是在这里publicSqlCommand(Configurationcon
- 从MIXED模式到主从一致性:深入解析Binlog格式的智能切换机制
引言:Binlog的核心价值与格式选择难题在MySQL的数据库生态中,Binlog(二进制日志)是数据复制、增量备份和灾难恢复的核心组件。其记录格式(STATEMENT、ROW、MIXED)直接决定了主从同步的行为逻辑。其中,MIXED模式的设计初衷是为了在“可读性”和“数据一致性”之间寻找平衡,但它的动态切换机制常常成为开发者困惑的源头。本文将通过实际场景分析,结合MySQL内核逻辑,揭示MIX
- MySQL数据库笔记——主从复制
Good Note
MySQL数据库笔记数据库mysql笔记sql数据库架构
大家好,这里是编程Cookbook,关注公众号「编程Cookbook」,获取更多面试资料。本文详细介绍MySQL的主从复制,从原理到配置再到同步过程。文章目录简介核心组件主从复制的原理作用主从复制的线程模型主从复制的模式形式一主一从一主多从多主一从双主复制级联复制复制的方式基于语句的逻辑复制(Statement-BasedReplication,SBR)基于行的物理复制(Row-BasedRepl
- SQL注入攻击
Wlq0415
数据库服务器运维
SQL注入攻击是指攻击者通过在输入字段中插入恶意SQL代码,以此来影响应用程序与数据库之间的交互,进而非法获取或篡改数据库中的数据。这种攻击利用了应用程序对用户输入缺乏充分验证或过滤的情况。抵御SQL注入攻击的两种常见方式包括:使用参数化查询(PreparedStatements):参数化查询是一种编程技术,它将SQL语句和用户输入分开处理。这样可以确保用户输入的数据仅被视为数据,而不是SQL代码
- MyBatis中是如何对占位符进行赋值的?
冰糖心书房
2025Java面试系列mybatis
MyBatis中对占位符进行赋值的过程主要由PreparedStatement和参数处理器(ParameterHandler)协同完成。1.SQL语句中的占位符:MyBatis支持两种占位符:#(预编译参数):推荐使用。MyBatis会使用PreparedStatement的占位符?来处理。PreparedStatement会对参数进行预编译和类型检查,可以防止SQL注入攻击。例如:SELECT*
- 聪明办法学python第4次笔记
weixin_44811994
笔记
目录变量Variables新值的数据类型不必与旧值相同变量是一个标签变量命名规则:元组的解包函数Functions`header`用于定义函数的**名称**和**参数**`body`包含函数执行的语句(`statement`)我们使用**函数名**来调用函数函数可以有任意多个参数,也可以一个都没有参数的数量要匹配语句与表达式StatementsandExpressions表达式定义:Anexpre
- JDBC Java连接数据库
nqqcat~
javaidea
1.准备下载jar——QQ群mysql-connect-java新建工程及目录添加驱动:把jar包添加到项目中,并添加到类库新建数据库新建表2.编写代码目标:创建链接打通连接四个参数驱动;URL;用户名;密码五个步骤加载驱动;创建连接;创建Statement;执行SQL;关闭,释放资源packagecom.wdzl.demo01;importjava.sql.Connection;importja
- Invalid bound statement, No converter found for return value of type:
噢!不杰克
springboot
SpringBoot2.0学习的Bug(Invalidboundstatement,Noconverterfoundforreturnvalueoftype:)一、Invalidboundstatement:绑定语句无效,这个问题很复杂,每一个人的解决方式不同,我的是mapper-locations中映射路径问题,我看着没问题,但还是重新copy路径试了一下。还真是这个问题。mybatis:con
- Oracle 12CR2 中alert.log出现大量的 WARNING: too many parse errors 告警
weixin_34007886
数据库运维
Oracle12CR2中alert.log出现大量的WARNING:toomanyparseerrors告警日志如下:2018-06-24T17:16:21.024586+08:00WARNING:toomanyparseerrors,count=3800SQLhash=0x03b77f5bPARSEERROR:ospid=6223,error=1031forstatement:2018-06-2
- 打卡信奥刷题(865)用C++信奥P11077[普及组/提高] 「FSLOI Round I」石子
Loge编程生活
C++c++开发语言算法青少年编程数据结构
P11077「FSLOIRoundI」石子题目背景Englishstatement.YoumustsubmityourcodeattheChineseversionofthestatement.小F和小L正在玩一种古老的博弈游戏的改版。题目描述给定nnn堆石子,第iii堆有aia_iai个石子。设序列a1,a2,⋯ ,ana_1,a_2,\cdots,a_na1,a2,⋯,an的平均数为xxx。此
- 【YashanDB 知识库】由于 druid 中间件配置导致异常
数据库
问题现象某客户的业务(Java框架)运行时报如下异常:问题的风险及影响客户的业务无法正常运行问题影响的版本所有的yashandb版本问题发生原因druid中间件有如下参数,可以控制是否缓存PreparedStatement,客户现场为如下配置:share-prepared-statements:truepool-prepared-statements:truemax-open-prepared-s
- Spring Boot整合MyBatis
BugAndWarning
SpringBoot的学习springbootmybatistomcatintellijideajava服务器后端
SpringBoot整合MyBatis在SpringBoot项目中,使用MyBatis是一种十分流行的数据访问方式。相对于Javaweb通过原生JDBC访问数据库,MyBatis的操作会非常的简单。原生JDBC访问数据库使用原生JDBC进行数据库操作如下:加载数据库驱动程序。获取数据库连接。创建Statement/PreparedStatement对象。执行SQL语句。处理查询结果。关闭资源。使用
- Python基础—条件控制和循环、函数、模块
三言不语
pythonpython开发语言
Python基础—条件控制和循环、函数、模块条件控制和循环if...elseif...else语句yaml代码解读复制代码ifcondition_1:statement_block_1elifcondition_2:statement_block_2else:statement_block_3while循环bash代码解读复制代码count=0whilecount>>deff(a,b,*,c):.
- DTrace简介
lw1a2
SolarisLinuxC/C++stringfunctionmoduleactioncmd存储
基本语法probe/optionalpredicates/{optionalactionstatements;}其中:1)probe:探针,即所要探查的对象。2)optionalpredicates:DTrace脚本没有if语句,使用/optionalpredicates/来替代。3)optionalactionstatements;:探针命中后执行的操作。探针(probe)provider:mo
- PostgreSQL:更新字段慢
喝醉酒的小白
PGpostgresql数据库
目录标题PostgreSQL慢查询优化与`pg_stat_statements`使用1.启用慢查询日志2.使用`pg_stat_statements`扩展收集查询统计信息3.查找执行时间较长的查询4.分析慢查询的执行计划5.优化查询6.检查并发连接和系统资源7.进一步优化8.查看某条SQL1.**如何生成`query_id`**2.**`query_id`是否会变化?**3.**是否会变动?**4
- QUESTION 60、Adaptive plans
黄继生 jisen
060
WhichthreestatementsaretrueaboutadaptiveSQLplanmanagement?A.Itautomaticallyperformsverificationorevolvesnon-acceptedplans,inCOMPREHENSIVEmodewhentheyperformbetterthanexistingacceptedplans.B.Theoptimiz
- mysql从库处理报错You must reset your password using ALTER USER statement before executing this statement
蜗牛去旅行吧
mysql数据库
在linux中安装好MySQL并完成初始化配置后,使用默认生成的root用户密码登录MySQL时,可能会出现无法执行任何语句的情况,提示「YoumustresetyourpasswordusingALTERUSERstatementbeforeexecutingthisstatement」。这是因为MySQL5.7版本后,用户表的密码字段由password改为了authentication_str
- Mybatis中 #{} 和 ${} 的区别是什么?
《小书生》
Mybatismybatis
${}是Properties文件中的变量占位符,它可以用于标签属性值和sql内部,属于原样文本替换,可以替换任意内容示例:根据参数按任意字段排序select*fromusersorderby${orderCols}#{}是sql的参数占位符,MyBatis会将sql中的#{}替换为?号,在sql执行前会使用PreparedStatement的参数设置方法,按序给sql的?号占位符设置参数值,比如p
- Python's SQLAlchemy and Object-Relational Mapping
zhanglizhuo
Python
Acommontaskwhenprogramminganywebserviceistheconstructionofasoliddatabasebackend.Inthepast,programmerswouldwriterawSQLstatements,passthemtothedatabaseengineandparsethereturnedresultsasanormalarrayofrec
- Mybatis 的插件,环境配置,映射器
or77iu_N
MyBatismybatisjava
1、插件(plugins)MyBatis允许你在映射语句执行过程中的某一点进行拦截调用。默认情况下,MyBatis允许使用插件来拦截的方法调用包括:Executor(update,query,flushStatements,commit,rollback,getTransaction,close,isClosed)ParameterHandler(getParameterObject,setPar
- select case 语句详解
山水CAD筑梦人
函数(VBA)数据库sqlvba
vba中常见的分情况选择语句有ifelseif语句、selectcase语句,本文详细讲解selectcase语句用法及实例。SelectCase语句根据表达式的值,来决定执行几组语句中的其中之一。语法SelectCasetestexpression[Caseexpressionlist-n[statements-n]]...[CaseElse[elsestatements]]EndSelectS
- Mybatis Plus 真正批量插入
癸酉金鸡
mybatis
一、MybatisPlus默认批量插入saveBatch方法在IService中,是使用同一个sqlSession,这相比遍历集合循环insert来说有一定的性能提升,但是这并不是sql层面真正的批量插入。二、jdbc添加rewriteBatchedStatements=true无法改变本质三、真正批量插入继承DefaultSqlInjector自定义sql注入器publicclassMySqlI
- Mybatis中的Dao接口工作原理
扯淡吧 Pino曹
mybatissqljava
简要概述一下Mybatis中的Dao接口工作原理Dao接口就是Mapper接口。接口的全限名就是映射文件中的namespace的值接口的方法名就是映射文件中的MappedStatement的id值接口方法内的参数,就是传递给sql的参数。Mapper接口是没有实现类的,当调用接口方法时,接口全限名+方法名拼接字符串作为key值,可唯一定位一个MappedStatement。Dao接口的工作原理是J
- Java实现SQLite数据库克隆
行云斡
Java实战演练数据库javasqlite
Java实现SQLite数据库克隆题目要求过程整理分步实现完整代码改进空间转载请注明出处题目要求Writeaprogram(inJavaandusingJDBC)thatclonesaSQLitedatabaseandproducesatextual“backup”ofthecontents.ThistextualbackupshouldconsistofSQLstatementsthatwill
- 2月第二讲:mybatis是如何识别分表位的
2501_90442144
mybatis
带着问题,我花了不少时间深入了读了一下这部分的源码,终于搞清楚了,借本文分享一下。本文主要环境是mybatis-plus-boot-starter3.4.3,不过用的基本上仍然是mybatis的特性。流程图以查询为例,可以先看下流程图,大致了解一下整个过程。关键的类和对象在流程图里出现了一些类和其实例化的对象,有必要选其中关键的介绍一下。MappedStatement类全名org.apache.i
- 【无标题】
Fansv587
数据结构
牛客刷题记录错题Java只能输入零和非零开头的数字,正确的正则表达式是:^(0|[1-9][0-9]*)$在一个有8个int数据的数组中,随机给出数组的数据,找出最大和第二大元素一定需要进行(9)次比较:Whichstatementdeclaresavariableawhichissuitableforreferringtoanarrayof50stringobjects?在java中,声明一个数
- java短路运算符和逻辑运算符的区别
3213213333332132
java基础
/*
* 逻辑运算符——不论是什么条件都要执行左右两边代码
* 短路运算符——我认为在底层就是利用物理电路的“并联”和“串联”实现的
* 原理很简单,并联电路代表短路或(||),串联电路代表短路与(&&)。
*
* 并联电路两个开关只要有一个开关闭合,电路就会通。
* 类似于短路或(||),只要有其中一个为true(开关闭合)是
- Java异常那些不得不说的事
白糖_
javaexception
一、在finally块中做数据回收操作
比如数据库连接都是很宝贵的,所以最好在finally中关闭连接。
JDBCAgent jdbc = new JDBCAgent();
try{
jdbc.excute("select * from ctp_log");
}catch(SQLException e){
...
}finally{
jdbc.close();
- utf-8与utf-8(无BOM)的区别
dcj3sjt126com
PHP
BOM——Byte Order Mark,就是字节序标记 在UCS 编码中有一个叫做"ZERO WIDTH NO-BREAK SPACE"的字符,它的编码是FEFF。而FFFE在UCS中是不存在的字符,所以不应该出现在实际传输中。UCS规范建议我们在传输字节流前,先传输 字符"ZERO WIDTH NO-BREAK SPACE"。这样如
- JAVA Annotation之定义篇
周凡杨
java注解annotation入门注释
Annotation: 译为注释或注解
An annotation, in the Java computer programming language, is a form of syntactic metadata that can be added to Java source code. Classes, methods, variables, pa
- tomcat的多域名、虚拟主机配置
g21121
tomcat
众所周知apache可以配置多域名和虚拟主机,而且配置起来比较简单,但是项目用到的是tomcat,配来配去总是不成功。查了些资料才总算可以,下面就跟大家分享下经验。
很多朋友搜索的内容基本是告诉我们这么配置:
在Engine标签下增面积Host标签,如下:
<Host name="www.site1.com" appBase="webapps"
- Linux SSH 错误解析(Capistrano 的cap 访问错误 Permission )
510888780
linuxcapistrano
1.ssh -v hdfs@192.168.18.133 出现
Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password).
错误
运行状况如下:
OpenSSH_5.3p1, OpenSSL 1.0.1e-fips 11 Feb 2013
debug1: Reading configuratio
- log4j的用法
Harry642
javalog4j
一、前言: log4j 是一个开放源码项目,是广泛使用的以Java编写的日志记录包。由于log4j出色的表现, 当时在log4j完成时,log4j开发组织曾建议sun在jdk1.4中用log4j取代jdk1.4 的日志工具类,但当时jdk1.4已接近完成,所以sun拒绝使用log4j,当在java开发中
- mysql、sqlserver、oracle分页,java分页统一接口实现
aijuans
oraclejave
定义:pageStart 起始页,pageEnd 终止页,pageSize页面容量
oracle分页:
select * from ( select mytable.*,rownum num from (实际传的SQL) where rownum<=pageEnd) where num>=pageStart
sqlServer分页:
- Hessian 简单例子
antlove
javaWebservicehessian
hello.hessian.MyCar.java
package hessian.pojo;
import java.io.Serializable;
public class MyCar implements Serializable {
private static final long serialVersionUID = 473690540190845543
- 数据库对象的同义词和序列
百合不是茶
sql序列同义词ORACLE权限
回顾简单的数据库权限等命令;
解锁用户和锁定用户
alter user scott account lock/unlock;
//system下查看系统中的用户
select * dba_users;
//创建用户名和密码
create user wj identified by wj;
identified by
//授予连接权和建表权
grant connect to
- 使用Powermock和mockito测试静态方法
bijian1013
持续集成单元测试mockitoPowermock
实例:
package com.bijian.study;
import static org.junit.Assert.assertEquals;
import java.io.IOException;
import org.junit.Before;
import org.junit.Test;
import or
- 精通Oracle10编程SQL(6)访问ORACLE
bijian1013
oracle数据库plsql
/*
*访问ORACLE
*/
--检索单行数据
--使用标量变量接收数据
DECLARE
v_ename emp.ename%TYPE;
v_sal emp.sal%TYPE;
BEGIN
select ename,sal into v_ename,v_sal
from emp where empno=&no;
dbms_output.pu
- 【Nginx四】Nginx作为HTTP负载均衡服务器
bit1129
nginx
Nginx的另一个常用的功能是作为负载均衡服务器。一个典型的web应用系统,通过负载均衡服务器,可以使得应用有多台后端服务器来响应客户端的请求。一个应用配置多台后端服务器,可以带来很多好处:
负载均衡的好处
增加可用资源
增加吞吐量
加快响应速度,降低延时
出错的重试验机制
Nginx主要支持三种均衡算法:
round-robin
l
- jquery-validation备忘
白糖_
jquerycssF#Firebug
留点学习jquery validation总结的代码:
function checkForm(){
validator = $("#commentForm").validate({// #formId为需要进行验证的表单ID
errorElement :"span",// 使用"div"标签标记错误, 默认:&
- solr限制admin界面访问(端口限制和http授权限制)
ronin47
限定Ip访问
solr的管理界面可以帮助我们做很多事情,但是把solr程序放到公网之后就要限制对admin的访问了。
可以通过tomcat的http基本授权来做限制,也可以通过iptables防火墙来限制。
我们先看如何通过tomcat配置http授权限制。
第一步: 在tomcat的conf/tomcat-users.xml文件中添加管理用户,比如:
<userusername="ad
- 多线程-用JAVA写一个多线程程序,写四个线程,其中二个对一个变量加1,另外二个对一个变量减1
bylijinnan
java多线程
public class IncDecThread {
private int j=10;
/*
* 题目:用JAVA写一个多线程程序,写四个线程,其中二个对一个变量加1,另外二个对一个变量减1
* 两个问题:
* 1、线程同步--synchronized
* 2、线程之间如何共享同一个j变量--内部类
*/
public static
- 买房历程
cfyme
2015-06-21: 万科未来城,看房子
2015-06-26: 办理贷款手续,贷款73万,贷款利率5.65=5.3675
2015-06-27: 房子首付,签完合同
2015-06-28,央行宣布降息 0.25,就2天的时间差啊,没赶上。
首付,老婆找他的小姐妹接了5万,另外几个朋友借了1-
- [军事与科技]制造大型太空战舰的前奏
comsci
制造
天气热了........空调和电扇要准备好..........
最近,世界形势日趋复杂化,战争的阴影开始覆盖全世界..........
所以,我们不得不关
- dateformat
dai_lm
DateFormat
"Symbol Meaning Presentation Ex."
"------ ------- ------------ ----"
"G era designator (Text) AD"
"y year
- Hadoop如何实现关联计算
datamachine
mapreducehadoop关联计算
选择Hadoop,低成本和高扩展性是主要原因,但但它的开发效率实在无法让人满意。
以关联计算为例。
假设:HDFS上有2个文件,分别是客户信息和订单信息,customerID是它们之间的关联字段。如何进行关联计算,以便将客户名称添加到订单列表中?
&nbs
- 用户模型中修改用户信息时,密码是如何处理的
dcj3sjt126com
yii
当我添加或修改用户记录的时候对于处理确认密码我遇到了一些麻烦,所有我想分享一下我是怎么处理的。
场景是使用的基本的那些(系统自带),你需要有一个数据表(user)并且表中有一个密码字段(password),它使用 sha1、md5或其他加密方式加密用户密码。
面是它的工作流程: 当创建用户的时候密码需要加密并且保存,但当修改用户记录时如果使用同样的场景我们最终就会把用户加密过的密码再次加密,这
- 中文 iOS/Mac 开发博客列表
dcj3sjt126com
Blog
本博客列表会不断更新维护,如果有推荐的博客,请到此处提交博客信息。
本博客列表涉及的文章内容支持 定制化Google搜索,特别感谢 JeOam 提供并帮助更新。
本博客列表也提供同步更新的OPML文件(下载OPML文件),可供导入到例如feedly等第三方定阅工具中,特别感谢 lcepy 提供自动转换脚本。这里有导入教程。
- js去除空格,去除左右两端的空格
蕃薯耀
去除左右两端的空格js去掉所有空格js去除空格
js去除空格,去除左右两端的空格
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>&g
- SpringMVC4零配置--web.xml
hanqunfeng
springmvc4
servlet3.0+规范后,允许servlet,filter,listener不必声明在web.xml中,而是以硬编码的方式存在,实现容器的零配置。
ServletContainerInitializer:启动容器时负责加载相关配置
package javax.servlet;
import java.util.Set;
public interface ServletContainer
- 《开源框架那些事儿21》:巧借力与借巧力
j2eetop
框架UI
同样做前端UI,为什么有人花了一点力气,就可以做好?而有的人费尽全力,仍然错误百出?我们可以先看看几个故事。
故事1:巧借力,乌鸦也可以吃核桃
有一个盛产核桃的村子,每年秋末冬初,成群的乌鸦总会来到这里,到果园里捡拾那些被果农们遗落的核桃。
核桃仁虽然美味,但是外壳那么坚硬,乌鸦怎么才能吃到呢?原来乌鸦先把核桃叼起,然后飞到高高的树枝上,再将核桃摔下去,核桃落到坚硬的地面上,被撞破了,于是,
- JQuery EasyUI 验证扩展
可怜的猫
jqueryeasyui验证
最近项目中用到了前端框架-- EasyUI,在做校验的时候会涉及到很多需要自定义的内容,现把常用的验证方式总结出来,留待后用。
以下内容只需要在公用js中添加即可。
使用类似于如下:
<input class="easyui-textbox" name="mobile" id="mobile&
- 架构师之httpurlconnection----------读取和发送(流读取效率通用类)
nannan408
1.前言.
如题.
2.代码.
/*
* Copyright (c) 2015, S.F. Express Inc. All rights reserved.
*/
package com.test.test.test.send;
import java.io.IOException;
import java.io.InputStream
- Jquery性能优化
r361251
JavaScriptjquery
一、注意定义jQuery变量的时候添加var关键字
这个不仅仅是jQuery,所有javascript开发过程中,都需要注意,请一定不要定义成如下:
$loading = $('#loading'); //这个是全局定义,不知道哪里位置倒霉引用了相同的变量名,就会郁闷至死的
二、请使用一个var来定义变量
如果你使用多个变量的话,请如下方式定义:
. 代码如下:
var page
- 在eclipse项目中使用maven管理依赖
tjj006
eclipsemaven
概览:
如何导入maven项目至eclipse中
建立自有Maven Java类库服务器
建立符合maven代码库标准的自定义类库
Maven在管理Java类库方面有巨大的优势,像白衣所说就是非常“环保”。
我们平时用IDE开发都是把所需要的类库一股脑的全丢到项目目录下,然后全部添加到ide的构建路径中,如果用了SVN/CVS,这样会很容易就 把
- 中国天气网省市级联页面
x125858805
级联
1、页面及级联js
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
&l