servlet应用具体实例
web,xml应用文件
1.<filter>参数
<filter>
<filter-name>encodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
<init-param>
<param-name>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!--多数据源支持监听 -->
java服务端: 每一个file对应一个具体的类,他会在web应用的servlet应用之响应
/*** Eclipse Class Decompiler plugin, copyright (c) 2012 Chao Chen (cnfree2000@hotmail.com) ***/
package org.springframework.web.filter; import java.io.IOException;
import javax.servlet.FilterChain;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; public class CharacterEncodingFilter extends OncePerRequestFilter {
private String encoding;
private boolean forceEncoding = false; public void setEncoding(String encoding) {
this.encoding = encoding;
} public void setForceEncoding(boolean forceEncoding) {
this.forceEncoding = forceEncoding;
} protected void doFilterInternal(HttpServletRequest request,
HttpServletResponse response, FilterChain filterChain)
throws ServletException, IOException {
if ((this.encoding != null)
&& (((this.forceEncoding) || (request.getCharacterEncoding() == null)))) {
request.setCharacterEncoding(this.encoding);
if (this.forceEncoding) {
response.setCharacterEncoding(this.encoding);
}
}
filterChain.doFilter(request, response);
}
}
案例二xml
<!--多数据源支持监听 -->
<filter>
<filter-name>dataSourceFilter</filter-name>
<filter-class>cn.jasgroup.jasframework.dataaccess.filter.DataSourceFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>dataSourceFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
java服务器端
/*** Eclipse Class Decompiler plugin, copyright (c) 2012 Chao Chen (cnfree2000@hotmail.com) ***/
package cn.jasgroup.jasframework.dataaccess.filter; import cn.jasgroup.jasframework.dataaccess.observer.DataSourceObserver;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest; public class DataSourceFilter implements Filter {
public void destroy() {
} public void doFilter(ServletRequest request, ServletResponse response,
FilterChain filterChain) throws IOException, ServletException {
HttpServletRequest req = (HttpServletRequest) request;
String datasource = req.getParameter("dataSourceName");
if ((datasource != null) && (!("".equals(datasource)))) {
DataSourceObserver.setDataSourceName(datasource);
}
filterChain.doFilter(request, response);
} public void init(FilterConfig arg0) throws ServletException {
}
}
respoonser实例
/**
* 查询任意圈定区域所在工区信息
*
* @param request
* @param response
* @return
* @throws IOException
*/
@RequestMapping("/queryWorkareaInfo")
@ResponseBody
public void queryWorkareaInfo(HttpServletRequest request, HttpServletResponse response) throws IOException {
WorkareaInfoBo winfoBo = new WorkareaInfoBo();
String workareaName = request.getParameter("workareaName"); String wellIds = request.getParameter("wellIds");
String wellNames = request.getParameter("wellNames");
try {
wellNames = URLDecoder.decode(wellNames, "UTF-8");
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} // 生产层位
String cengwei = request.getParameter("cengwei"); String date_start = request.getParameter("date_start");
String date_end = request.getParameter("date_end");
if (StringUtils.isNotBlank(cengwei)) {
try {
cengwei = URLDecoder.decode(cengwei, "UTF-8");
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
if (!cengwei.equals("所有层位")) {
String cengwei_wellname = "";
String[] wellarr = wellNames.split(";");
wellNames="";
for (String val : wellarr) {
cengwei_wellname += "'" + val + "',";
}
cengwei_wellname += "@";
cengwei_wellname = cengwei_wellname.replace(",@", ""); // cengwei = getChildren(cengwei); // wellNames = "";
// String hql_per = "from Perforationdata where perforationposition in('" + cengwei + "') and wellnum in("
// + cengwei_wellname + ")";
String hql_per = "select distinct(jh) from YCSY_NEWHORIZON where cw in('" + cengwei + "') and jh in("
+ cengwei_wellname + ")"; List<NewHorizon> list = workareaInfoService.queryPerforation(hql_per);
for (Iterator iterator = list.iterator(); iterator.hasNext();) {
NewHorizon perforationdata = (NewHorizon) iterator.next();
wellNames += perforationdata.getJh() + ";";
}
}
}
// 生产层位end
/*
* try { wellNames = new
* String(wellNames.getBytes("ISO-8859-1"),"UTF-8"); } catch
* (UnsupportedEncodingException e1) { // TODO Auto-generated catch
* block e1.printStackTrace(); }
*/ Map<String, Object> map = new HashMap<String, Object>();
PageRequest pageRequest = this.getPage(request);
System.out.println(pageRequest + "=pageRequest");
// 根据工区名称查询所有井名称
if (!"".equals(workareaName) && null != workareaName) {
String str = "from Wellinfo where workArea = '" + workareaName + "'";
List<Wellinfo> wellInfoList = workareaInfoService.queryWellinfoList(pageRequest, str);
if (wellInfoList.size() > 0) {
String wellNum = "";
for (int i = 0; i < wellInfoList.size(); i++) {
wellNum = wellInfoList.get(i).getWellName();
wellIds += wellNum + ";";
}
}
}
String hql = joinHql(wellNames, workareaName);
String cyhql = "";
String zshql = "";
if (StringUtils.isNotBlank(workareaName)) {
cyhql = "from Wellinfo where wellType <> '注水井' and workArea = '" + workareaName + "'";
zshql = "from Wellinfo where wellType like '%注水%' and workArea = '" + workareaName + "'";
} else if (StringUtils.isNotBlank(wellIds)) {
cyhql = joinCyWellHql(wellIds);
zshql = joinZsWellHql(wellIds);
} else if (StringUtils.isNotBlank(wellNames)) {
cyhql = joinCyWellHqlName(wellNames);
zshql = joinZsWellHqlName(wellNames);
}
WorkareaInfoBo wibo = workareaInfoService.queryWorkareaInfo(pageRequest, hql + "@" + cyhql + "@" + zshql,
date_start, date_end, wellNames,cengwei);
String sql = "select tmcl cl ,qkzymj mj from ycab03 where qkmc = '东仁沟区'and gxsj=(select max(gxsj) gxsj from ycab03 where qkmc = '东仁沟区')";
List<AreaSeartH> ah = dataReportService.queryAreaAndChuliangServer(sql,AreaSeartH.class);
JSONObject obj = new JSONObject();
DecimalFormat df=new DecimalFormat("0.00");
if(ah.size()>0){
double yujichuliang;
double suoxuanmianji;
obj.put("dzreserves", ah.get(0).getCl());
obj.put("workarea", ah.get(0).getMj());
if(StringUtils.isNotEmpty(ah.get(0).getCl())&&StringUtils.isNotEmpty(wibo.getOilWellNum())){
yujichuliang = Double.parseDouble(ah.get(0).getCl())/1137*Double.parseDouble(wibo.getOilWellNum());
obj.put("guessGeologicla",df.format(yujichuliang));
}else{
obj.put("guessGeologicla", "0.00");
}
if(StringUtils.isNotEmpty(ah.get(0).getMj())&&StringUtils.isNotEmpty(wibo.getOilWellNum())){
suoxuanmianji = Double.parseDouble(ah.get(0).getMj())/1137*Double.parseDouble(wibo.getOilWellNum());
obj.put("calculatearea",df.format(suoxuanmianji));
}else{
obj.put("calculatearea", "0.00");
}
}else{
obj.put("dzreserves", "0.00");
obj.put("workarea", "0.00");
}
obj.put("endDate", wibo.getEndDate());
obj.put("injectWaterNum",wibo.getInjectWaterNum());
obj.put("productOilNum",wibo.getProductOilNum());
obj.put("oilWellNum",wibo.getOilWellNum());
obj.put("startDate", wibo.getStartDate());
obj.put("waterWellNum", wibo.getWaterWellNum());
obj.put("wellNames", wibo.getWellNames());
obj.put("yeliang",wibo.getYeliang()); obj.put("currcyou", wibo.getCurrcyou());
obj.put("currzshui",wibo.getCurrzshui());
obj.put("curryeliang", wibo.getCurryeliang());
response.getWriter().write(obj.toString());
response.getWriter().flush();
response.getWriter().close();
}
servlet应用具体实例的更多相关文章
- 每一个Servlet只有一个实例,多个线程
每一个Servlet只有一个实例,多个线程: Servlet: package com.stono.servlet.synchronize; import javax.servlet.http.Htt ...
- JSP+JavaBean+Servlet工作原理实例…
JSP+JavaBean+Servlet工作原理实例讲解 首先,JavaBean和Servlet虽都是Java程序,但是是完全不同的两个概念.引用mz3226960提出的MVC的概念,即M-model ...
- JSP+servlet简单登录实例
一个简单的jsp+servlet实例,实现简单的登录 转载▼ http://blog.sina.com.cn/s/blog_5c5bc9070100z7wb.html 开发环境myeclips ...
- Tomcat+Servlet登录页面实例
概念 Tomcat server是一个免费的开放源码的Web 应用server,属于轻量级应用server,在中小型系统和并发訪问用户不是非常多的场合下被普遍使用,是开发和调试JSP 程序的首选. ...
- (详细)Eclips+jsp+servlet+mysql+登录实例+源代码
欢迎任何形式的转载,但请务必注明出处. 该教程较全,从软件的安装以及相关的环境配置我都放置了相关教程的链接,读者可直接点击进入.自己写电商网站作业时查找了很多资料,但都不是很全,所以趁着寒假写了这份教 ...
- Javabean+servlet+JSP(html)实例应用
大家都知道Javabean+servlet+JSP是最简单的MVC模式.的确,在一个小型的项目中,这个模式完全够用. 它优雅并且简洁.加上jQueryui的完美展示效果,让这个模式看起来非常合适.当然 ...
- Servlet程序开发--实例操作:MVC设计模式应用
以前做过一个登录程序,是用JSP+JavaBean完成的,最大的问题,JSP文件内容太多了. 1. VO 2. DBC 3. DAO 3.1 impl 3.2 proxy 4. Factory 5. ...
- Servlet的HelloWorld实例
以下内容引用自http://wiki.jikexueyuan.com/project/servlet/first-example.html: Servlets是Java类,服务于HTTP请求并实现了j ...
- Servlet学习(三)——实例:用户登录并记录登陆次数
1.前提:在Mysql数据库下建立数据库web13,在web13下创建一张表user,插入几条数据如下: 2.创建HTML文件,命名为login,作为登录界面(以post方式提交) <!DOCT ...
随机推荐
- 在Windows下忘记MySQL最高用户权限密码的解决方案
1.打开MySQL配置文件 my.ini中,添加上skip-grant-tables,可以添加到文件的末尾或者是这添加到[mysqld]的下面(直接添加在my.ini文件最后亲测可以,但是在[mysq ...
- 51nod 1257 背包问题 V3
1257 背包问题 V3 基准时间限制:3 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 N个物品的体积为W1,W2......Wn(Wi为整数),与之相对应的价值为P1,P2.. ...
- 包装设计模式的实现以改进BufferedReader中的readLine方法为例
实现与目标对象相同的接口 BufferedReader 定义一个变量记住目标对象 定义一个构造器接收被增强对象 覆盖需要增强的方法 对于不想增强的方法,直接调用目标对象的方法. package ...
- WPF解析Fnt字体
偶遇需要再 WPF中加载Fnt字体,此做... using System; using System.Collections.Generic; using System.Drawing; using ...
- 好项目烂架构的问题,四年coder的吐槽
四年多码农,毕业后在一家小私企做前端:(初始asp.net,对oo有了比较深切的理解:处于对某空间的效仿,对前端技术架构理解的比较透彻): 在这家公司混了4个月之后跳出来想自己单干: 自己接了个小项目 ...
- 一点关于Ajax和一个等待图标的显示
一点关于Ajax和一个等待图标的显示 1.首先Ajax是asynchronous Java-Script and XML的简写.翻译过来就是异步的JS和XML. 2它的优点就是能不更新页面的情况下,得 ...
- EntityFramework Add方法与Attach区别
一 先发问. 问题:在使用EF过程中,能否有一个方法可以直接执行传入的SQL语句.纠结的只找到了调用存储过程的方法,难道要SqlHelper.cs? 二 友情提示 本文内容参考自MSDN. 三 ...
- android编程常见问题-No Launcher activity found!
新手编程常见的问题: 问题表现: console提示:No Launcher activity found! The launch will only sync the application pac ...
- BitNami一键安装Redmine(转)
1. 简介 对于一个新手,如果严格按照官方文档来安装redmine,我想会“疯”掉的.有没有一种简便的方法.有滴,那就是BitNami. BitNami提供redmine的一键安装程序,简单.易用.方 ...
- 【WCF--初入江湖】08 并发与实例模式
08 并发与实例模式 1. 实例上下文模式 一个服务代理:servicePoxy ChannelFactory<IService1> factoryservicel = new Cha ...