设为首页 收藏本站
查看: 790|回复: 0

[经验分享] 将数据源配置放在Tomcat的config目录下,使用curl工具上传文件

[复制链接]

尚未签到

发表于 2018-12-6 13:40:02 | 显示全部楼层 |阅读模式
  1.web.xml中的配置





  •   ProxoolConfigFile
  •   /WEB-INF/proxool.config


  •     com.ProxoolListener

  •    
  •     Admin   
  •     org.logicalcobwebs.proxool.admin.servlet.AdminServlet     

  •    
  •     Admin   
  •     /admin     


  •    
  •     AxxxDispatcher   
  •     com.Dispatcher   
  •          
  •    
  •     AxxxDispatcher   
  •     /axxx/*   




  2.在proxool.config中的配置


  • proxool.house-keeping-sleep-time=90000
  • proxool.maximum-connection-lifetime=300000
  • proxool.maximum-active-time=300000
  • proxool.prototype-count=5
  • proxool.maximum-connection-count=10
  • proxool.minimum-connection-count=1
  • proxool.test-before-use=true
  • proxool.house-keeping-sleep-time=60000
  • proxool.house-keeping-test-sql=select getdate()

  3.ProxoolListener中的代码
  配置文件中的改动,Tomcat会自动刷新。


  • import java.sql.Connection;
  • import java.sql.DriverManager;
  • import java.sql.SQLException;
  • import java.util.Properties;

  • import javax.servlet.ServletContext;
  • import javax.servlet.ServletContextEvent;
  • import javax.servlet.ServletContextListener;

  • import org.logicalcobwebs.proxool.ProxoolFacade;

  • public class ProxoolListener implements ServletContextListener {
  •     final static String CONFIGFILE = "ProxoolConfigFile";
  •     final static String ALIAS = "db.alias";
  •     final static String HOST = "db.host";
  •     final static String PORT = "db.port";
  •     final static String DATABASE = "db.database";
  •     final static String LOGIN = "db.login";
  •     final static String PASS = "db.password";
  •     final static String DIRECTORY = "file.directory";   
  •     public static String path = null ;
  •     private static String alias;
  •     public void contextDestroyed(ServletContextEvent arg0) {
  •         // TODO Auto-generated method stub
  •         ProxoolFacade.shutdown(0);

  •     }

  •     public void contextInitialized(ServletContextEvent ctxEvent) {
  •         // TODO Auto-generated method stub
  •         Properties prop = new Properties();
  •         ServletContext ctx = ctxEvent.getServletContext();
  •         String configFile = ctx.getInitParameter(CONFIGFILE);
  •         try {
  •             prop.load(ctxEvent.getServletContext().getResourceAsStream(configFile));
  •             System.err.println(prop.getProperty("proxool.house-keeping-test-sql"));
  •             alias = ctx.getInitParameter(ALIAS);
  •             String host = ctx.getInitParameter(HOST);
  •             String port = ctx.getInitParameter(PORT);
  •             String database = ctx.getInitParameter(DATABASE);
  •             String login = ctx.getInitParameter(LOGIN);
  •             String password = ctx.getInitParameter(PASS);
  •             prop.setProperty("user", login);
  •             prop.setProperty("password", password);
  •             String driverClass = "net.sourceforge.jtds.jdbc.Driver";
  •             String driverUrl = "jdbc:jtds:sqlserver://"+host+":"+port+"/"+database;
  •             String url = "proxool." + alias + ":" + driverClass + ":" + driverUrl;
  •             Class.forName("org.logicalcobwebs.proxool.ProxoolDriver");
  •             ProxoolFacade.registerConnectionPool(url, prop);
  •             
  •             path = ctx.getInitParameter(DIRECTORY);
  •         }
  •         catch (Exception e){
  •             e.printStackTrace();
  •         }

  •     }
  •     public static Connection getConnection()throws SQLException {
  •         return DriverManager.getConnection("proxool."+alias);
  •     }

  • }

  4.在tomcat\conf\Catalina\localhost 目录下新建一个配置数据库信息的xml文件
  此xml文件的文件名就是项目的文件名,比如myTest.xml,不管path="/path" 或者docBase="D:\app.war",此时访问的项目名就是 http://127.0.0.1:8080/myTest/。



  •      
  •      
  •      
  •      
  •      
  •      
  •      


  5.此时启动Tomcat,http://127.0.0.1:8080/path/ 即可以访问。
  6.对于需要上传一些文件到该路径的,可以试用curl工具。用doPost的方式上传。
  比如使用cmd,打开文件所在目录,键入一下命令即可。


  • curl -k --data-binary @要上传的文件 -H "Content-Type:text/xml;charset=UTF-8"  http://127.0.0.1:8080/path/xxx/

  7.在Dispatcher中接收文件的代码


  • import java.io.File;
  • import java.io.FileOutputStream;
  • import java.io.IOException;
  • import java.io.InputStream;
  • import java.io.PrintWriter;
  • import java.io.StringWriter;
  • import java.io.Writer;
  • import java.sql.Connection;
  • import java.sql.SQLException;
  • import java.text.SimpleDateFormat;
  • import java.util.Calendar;
  • import java.util.Enumeration;

  • import javax.servlet.ServletException;
  • import javax.servlet.http.HttpServlet;
  • import javax.servlet.http.HttpServletRequest;
  • import javax.servlet.http.HttpServletResponse;

  • import org.simpleframework.xml.Serializer;
  • import org.simpleframework.xml.core.Persister;

  • import com.pansontech.common.DbTransaction;
  • import com.pansontech.common.db.ProxoolListener;
  • import com.pansontech.gdlgst.akzon.bean.DELVRY03;
  • import com.pansontech.gdlgst.akzon.util.ParserUtil;

  • public class Dispatcher extends HttpServlet {

  •     @Override
  •     protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
  •         // TODO Auto-generated method stub
  •         System.err.println("doGet");
  •         String output="Access Denied!";
  •         resp.setCharacterEncoding("UTF-8");
  •         Writer out = resp.getWriter();
  •         out.write(output);
  •         out.flush();
  •     }

  •     @Override
  •     protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
  •         int len = req.getContentLength();
  •         byte[] temp = new byte[len];
  •         Enumeration enu = req.getHeaderNames();
  •         while (enu.hasMoreElements()){
  •             String head = (String)enu.nextElement();
  •             System.err.println(head+":"+req.getHeader(head));
  •         }
  •         InputStream is = req.getInputStream();
  • //      SimpleDateFormat sdf=new SimpleDateFormat("yyyyMMddHHmmss");
  • //      String path = this.getServletContext().getRealPath("/")+sdf.format(Calendar.getInstance().getTime())+".xml";
  • //      System.err.println(path);
  • //      FileOutputStream fos = new FileOutputStream(path);
  •         int len1 = 0;
  •         int totalRead = 0;
  •         //放到byte[] temp中,这样能够保证网络问题引起的文件内容不完整。
  •         while ((totalRead

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-644035-1-1.html 上篇帖子: tomcat中间件提交表单数据量过大警告处理方案 下篇帖子: 用JMX远程监控Tomcat-12943214
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表