我的编程空间,编程开发者的网络收藏夹
学习永远不晚

java工程配置

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

java工程配置

安装

TOMCAT最新版本是5.0.29(http://jakarta.apache.org/site/binindex.cgi)

如果在WINDOWS下它可以自动找到你的JDK或者set JAVA_HOME=c:/jdk

在LINUX下需要先解压,然后设置JAVA_HOME

export JAVA_HOME=/usr/local/jdk

RUN

设置完毕后就可以运行tomcat服务器了,进入tomcat的bin目录,WINDOWS下用startup启动tomcat,linux下用startup.sh,相应的关闭tomcat的命令为shutdown和shutdown.sh。

启动服务后在浏览器里输入http://localhost:8080/来测试一下

目录结构

Bin:存放启动和关闭tomcat脚本。

Conf:包含不同的配置文件,server.xml(Tomcat的主要配置文件)。

Work:存放jsp编译后产生的class文件。

Webapp:存放应用程序示例,以后你要部署的应用程序也要放到此目录。

Logs:存放日志文件

Comm./server/shared:这三个文件夹下的LIB文件夹放jar文件。

配置server.xml文件

没有什么好说的,看TOMCAT的文档比较有用,这里提供一些主要的东西吧。

元素名

属性

解释

server

port

指定一个端口,这个端口负责监听关闭tomcat的请求

shutdown

指定向端口发送的命令字符串

service

name

指定service的名字

Connector(表示客户端和service之间的连接)

port

指定服务器端要创建的端口号,并在这个断口监听来自客户端的请求

minProcessors

服务器启动时创建的处理请求的线程数

maxProcessors

最大可以创建的处理请求的线程数

enableLookups

如果为true,则可以通过调用request.getRemoteHost()进行DNS查询来得到远程客户端的实际主机名,若为false则不进行DNS查询,而是返回其ip地址

redirectPort

指定服务器正在处理http请求时收到了一个SSL传输请求后重定向的端口号

acceptCount

指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理

connectionTimeout

指定超时的时间数(以毫秒为单位)

Engine(表示指定service中的请求处理机,接收和处理来自Connector的请求)

defaultHost

指定缺省的处理请求的主机名,它至少与其中的一个host元素的name属性值是一样的

Context(表示一个web应用程序,通常为WAR文件,关于WAR的具体信息见servlet规范)

docBase

应用程序的路径或者是WAR文件存放的路径

path

表示此web应用程序的url的前缀,这样请求的url为http://localhost:8080/path

final static private boolean VERBOSE = true; //打印控制台控制

//static Logger logger = Logger.getLogger(dbManager.class.getName());

private Context initCtx = null;

private Context ctx = null;

private DataSource ds = null;

private long timeout = 5000;

private Statement theStatement = null;

private PreparedStatement thePstmt = null;

public

dbManager() {

try {

initCtx = new InitialContext();

//init context,read config web.xml

if (initCtx == null) {

throw new Exception("Initial Failed!");

}

ctx = (Context) initCtx.lookup("java:comp/env");

//find "jdbc/SqlServerDB" object this configruation in the SERVER.XML of Tomcat

if (ctx != null) {

ds = (DataSource) ctx.lookup("jdbc/SqlServerDB");

}

if (ds == null) {

throw new Exception("Look up DataSource Failed!");

}

}

catch (Exception e) {

log(e, "Can’t get the Context!");

}

}

public synchronized

Connection getConnection() {

//get connection and set to delay time

long startTime = new java.util.Date().getTime();

Connection con = null;

while (con == null) {

con = newConnection();

if (con != null) {

//log("Create New Connection!");

break;

}

try {

log("连接超时,重新连接,等待" + timeout + "ms");

wait(timeout);

}

catch (InterruptedException e) {

log(e, "连接超时!");

}

if ( (new java.util.Date().getTime() - startTime) >= timeout) {

log("Connection timeout!");

break;

}

}

return con;

}

private

Connection newConnection() {

Connection con = null;

try {

con = ds.getConnection();

if (con == null) {

throw new Exception("Create Connection Failed!");

}

}

catch (Exception e) {

log("Create Connection Failed!");

System.out.println(e.getMessage());

}

return con;

}

public synchronized

void freeConnection(Connection conn,

Statement stmt,

PreparedStatement pstmt) {

try {

//close Statement

if (stmt != null) {

stmt.close();

stmt = null;

//log("Close Statement......");

}

//close PreparedStatement

if (pstmt != null) {

pstmt.close();

pstmt = null;

//log("Close PreparedStatement......");

}

}

catch (Exception e) {

System.out.println(e.getMessage());

}

try {

//close Connection

if (conn != null) {

conn.close();

conn = null;

//log("Close Connection......");

}

}

catch (SQLException e) {

log(e, "释放资源出错!");

}

}

private

void log(String s) {

if (VERBOSE) {

System.out.println(new java.util.Date() + ":" + s);

//logger.info(new java.util.Date()+s);

}

}

private

void logerr(Object ex) {

if (VERBOSE) {

//System.out.println(new java.util.Date()+":"+s);

//logger.error(ex);

}

}

private

void log(Throwable e, String msg) {

System.out.println(new java.util.Date() + ": " + msg);

//logger.info(new java.util.Date() + ": " + msg, e);

}

……

}

OK,你现在可以方便的使用连接池了,想要一个得一个,记得要释放哦,连接池的数量总是有限的。

二、中文问题照样很简单

每个国家(或区域)都规定了计算机信息交换用的字符编码集,如美国的扩展 ASCII码, 中国的 GB2312-80,日本的 JIS 等,作为该国家/区域内信息处理的基础,有着统一编码的重要作用。字符编码集按长度分为 SBCS(单字节字符集),DBCS(双字节字符集)两大类。早期的软件(尤其是操作系统),为了解决本地字符信息的计算机处理,出现了各种本地化版本(L10N),为了区分,引进了 LANG, Codepage 等概念。但是由于各个本地字符集代码范围重叠,相互间信息交换困难;软件各个本地化版本独立维护成本较高。因此有必要将本地化工作中的共性抽取出来,作一致处理,将特别的本地化处理内容降低到最少。这也就是所谓的国际化(I18N)。各种语言信息被进一步规范为 Locale 信息。处理的底层字符集变成了几乎包含了所有字形的 Unicode。

现在大部分具有国际化特征的软件核心字符处理都是以 Unicode 为基础的,在软件运行时根据当时的 Locale/Lang/Codepage 设置确定相应的本地字符编码设置,并依此处理本地字符。在处理过程中需要实现 Unicode 和本地字符集的相互转换,甚或以 Unicode 为中间的两个不同本地字符集的相互转换。这种方式在网络环境下被进一步延伸,任何网络两端的字符信息也需要根据字符集的设置转换成可接受的内容。

Java 语言内部是用 Unicode 表示字符的,遵守 Unicode V2.0。Java 程序无论是从/往文件系统以字符流读/写文件,还是往 URL 连接写 HTML 信息,或从 URL 连接读取参数值,都会有字符编码的转换。这样做虽然增加了编程的复杂度,容易引起混淆,但却是符合国际化的思想的。从理论上来说,这些根据字符集设置而进行的字符转换不应该产生太多问题。而事实是由于应用程序的实际运行环境不同,Unicode 和各个本地字符集的补充、完善,以及系统或应用程序实现的不规范,转码时出现的问题时时困扰着程序员和用户。

其实解决 JAVA 程序中的汉字编码问题的方法往往很简单,但理解其背后的原因,定位问题,还需要了解现有的汉字编码和编码转换。相信这样的东西大家都见过了

new String(request.getParameter("test").getBytes("iso-8859-1"),"GBK")

但这样的代码相信不是一个解决的办法,这样会增加程序的复杂度,写数据库,提交表单,URL中传中文参数,到处都是中文问题!作为一个连走路都要算计最短距离的懒人,当然不愿天天叨念着new String(request.getParameter("test").getBytes("iso-8859-1"),"GBK"),然汉战战兢兢的处理各种字符转换的问题,我跋山涉水,翻山越岭,终于找到了完美的解决方式,在TOMCAT中只需要简单的配置,引入2个文件就可以轻松搞定。

前提条件,每个页面使用

<%@ page contentType="text/html; charset=GBK" language="java" import="java.sql.*" errorPage="" %>

地球人都知道的东西。

步骤1:添加过滤器

在TOMCAT中找到这2个文件RequestDumperFilter.java,SetCharacterEncodingFilter.java,他们位于D:Tomcat5.0.27webappsjsp-examplesWEB-INFclassesfilters,加到你的工程文件里去,编译他们。

步骤2:配置WEB.XML

在web.xml里加入这一段

……

Set Character Encoding

filters.SetCharacterEncodingFilter

encoding

GBK

Set Character Encoding

/*

……

看到没有?这样你就不用写那些麻烦的转换代码了,当然这样还不足以解决问题。

步骤3:修改server.xml

在server.xml修改2个地方

maxThreads="150" minSpareThreads="25" maxSpareThreads="75"

enableLookups="false" redirectPort="8443" acceptCount="100"

debug="0" connectionTimeout="20000"

disableUploadTimeout="true" URIEncoding=’GBK’/>

port="8009" minProcessors="5" maxProcessors="75"

enableLookups="true" redirectPort="8443"

acceptCount="10" debug="0" connectionTimeout="0"

useURIValidationHack="false" protocol="AJP/1.3"

protocolHandlerClassName="org.apache.jk.server.JkCoyoteHandler"

URIEncoding=’GBK’/>

OK,搞定!

三、APACHE和TOMCAT他们俩关系非同一般

Apache和tomcat都是很优秀的软件,更可贵的是它们是免费的。其实他们2个都是jakarta项目的重要组成部分。按辈分来讲,TOMCAT是APACHE的儿子,APACHE的专长是解析静态文件,CGI,PHP……图片……,儿子当然不能抢了老爹的饭碗,所以TOMCAT只有在J2EE这个上面发愤图强,其实TOMCAT并非不能干他老爹的活,只是稳定性差点而已(偶没有明显的感觉,可能是商业炒作吧),现在大家明白为什么把他们2个扯一起了吧,上阵还靠父子兵呢~

把2个家伙整一起有大致有2种方法,一种是利用mod_jk2.so,一种是利用mod_jk_1.2.5_2.0.47.dll。这2个东东叫联接器(TOMCAT就是通过这家伙与apache勾搭上的)

利用mod_jk_1.2.5_2.0.47.dll在WINDOWS下整合

步骤1:准备材料

apache2.0.52

http://apache.te8.com/dist/httpd/binaries/win32/apache_2.0.52-win32-x86-no_ssl.msi

tomcat5.0.27

http://apache.linuxforum.net/dist/jakarta/tomcat-5/v5.0.19/bin/jakarta-tomcat-5.0.27.exe

JDK(这个不用说了吧^_^)

mod_jk_1.2.5_2.0.47.dll(关键是这个东东啊,找了我N久),据说在下面连接可以下到,最后在我同事那找到的。

http://apache.linuxforum.net/dist/jakarta/tomcat-connectors/jk/binaries/win32/mod_jk_1.2.5_2.0.47.dll

安装apache tomcatJDK。

步骤2:安装后设置环境变量

设置我的电脑属性高级环境变量新建系统变量 变量名:JAVA_HOME 变量值:C:JBuilderXjdk1.4 (指向JDK的实际安装路径);TOMCAT_HMOM 变量值:Tomcat5.0.27;lasspath 编辑变量值中加上 ……;%JAVA_HOME%bin;%JAVA_HOME%lib;%TOMCAT_HOME%bin;.;

测试一下,访问http://localhost和http://localhost:8080,默认安装是不会有什么错误的^_^

把连接器mod_jk_1.2.5_2.0.47.dll COPY到D:Apache2modules下。

步骤3:apache配置

在d:Apache2conf下找到httpd.conf,找到DirectoryIndex,在index.html后添加index.jsp;查找“listen”用于本机测试时:Listen 127.0.0.1:80,我的是这样设置的Listen *:80

查找AddDefaultCharset设置为AddDefaultCharset off,这样APACHE将以你页面定义的字符集解析页面。

在最后添加如下代码:

#localhost为本机,你可用本机ip

ServerAdmin darkxie@hotmail.com #你的mail地址

DocumentRoot F:/uutang/uutang #你的项目组根目录

ServerName dark #你的服务名,若你的机器有域名,设为域名

ErrorLog logs/ErrorLog.txt #错误日志

CustomLog logs/CustomLog.txt common #访问日志

JkMount /servlet/* ajp13 #让Apache支持对servlet传送,用以Tomcat解析

JkMount /*.jsp ajp13 #让Apache支持对jsp传送,用以Tomcat解析

JkMount /*.do ajp13 #让Apache支持对struts的action传送,用以Tomcat解析

LoadModule jk_module modules/mod_jk_1.2.5_2.0.47.dll

JkWorkersFile "D:/Tomcat5.0.27/conf/workers.properties"

JkLogFile "D:/Tomcat5.0.27/logs/mod_jk2.log"

JkLogLevel info

步骤4:tomcat配置

在d:Tomcat5conf下新建一个workers.properties文件 .内容如下:

workers.tomcat_home=d:Tomcat5 #让mod_jk模块知道Tomcat

workers.java_home=d:jdk1.3 #让mod_jk模块知道j2sdk

ps=

worker.list=ajp13 #模块版本,现有ajp13了,不要修改

worker.ajp13.port=8009 #工作端口,若没占用则不用修改

worker.ajp13.host=localhost #主机,若上面的Apache主机不为localhost,作相应修改

worker.ajp13.type=ajp13 #类型

worker.ajp13.lbfactor=1 #代理数,不用修改

修改TOMCAT的server.xml文件:

<!-- Define a Coyote/JK2 AJP 1.3 Connector on port 8009 -->

port="8009" minProcessors="5" maxProcessors="75"

enableLookups="true" redirectPort="8443"

acceptCount="10" debug="0" connectionTimeout="0"

useURIValidationHack="false" protocol="AJP/1.3"

protocolHandlerClassName="org.apache.jk.server.JkCoyoteHandler"

URIEncoding=’GBK’/>

让TOMCAT知道ajp13协议,apache和tomcat俩父子间靠这个协议沟通。

测试一下,访问http://localhost和http://localhost:8080,看到相同的页面没有?细心点,其实很简单,看看E文的帮助,搞定不成问题。

利用mod_jk2.so(也叫JK2)整合

jk2是一个jakarta-tomcat-connectors-jk2.0.4-win32-apache2.0.49.zip文件,主要用的是其中的mod_jk2.so。其实利用mod_jk2.so整合和利用mod_jk_1.2.5_2.0.47.dll整合大同小异,只是换了个联接器而已,现在一步一步整起来~

步骤1:没有多说的,安装好TOMCAT和APACHE

下载jakarta-tomcat-connectors-jk2.0.4-win32-apache2.0.49.zip,解压,将mod_jk2放到apache的安装文件夹下的modules文件夹中。

步骤2:apache配置

在/conf中加入一个work.properties文件,其内容如下:

<!--这个文件的作用不是很清楚,总之路径设置正确就行了。我的apache装在D:/Apache2,根据情况自己修改。-->

[shm]

file=D:/ /Apache2/logs/shm.file

size=1048576

<!--这个socket channel是必须的,port和host对应于tomcat端的设置。-->

#The socket channel

[channel.socket:localhost:8009]

port=8009

host=localhost

<!--worker,必须的。-->

#define the worker

[ajp13:localhost:8009]

channel=channel.socket:localhost:8009

<!--url mapping,我的主要是.jsp和struts的.do,servlet的话设置成[uri:/xxx/*]之类的。-->

#uri mapping

[uri:/*] #和第一种方式一样吧^_^

[uri:/*.jsp]

[uri:/*.do]

worker=ajp13:localhost:8009

在httpd.conf中,在LoadModule那里加入这句:

LoadModule jk2_module modules/mod_jk2.so

在最后加入这句:

JkSet config.file "conf/work.properties"

这是告诉apache去哪里找jk的配置的,根据具体情况修改。

还要修改一下DirectoryIndex,DirectoryIndex index.html index.html.var index.jsp查找“listen”用于本机测试时:Listen 127.0.0.1:80,我的是这样设置的Listen *:80。

当然还有我们的虚拟目录:

ServerAdmin darkxie@hotmail.com

DocumentRoot F:/uutang/uutang

ServerName dark

ErrorLog logs/ErrorLog.txt

CustomLog logs/CustomLog.txt common

#JkMount /servlet/* ajp13

#JkMount /*.jsp ajp13

#JkMount /*.do ajp13

步骤3:tomcat配置

Tomcat的端口设置为8080。

在/conf文件夹加入jk2.properties文件,其内容如下:

# Set the desired handler list

handler.list=apr,request,channelSocket

#

# Override the default port for the socketChannel

channelSocket.port=8009

TOMCAT自己已经生成了这个文件,找到相关的地方把注视去掉改一下就成。

注意:用这种方式整合最好是自己编译mod_jk2.so文件,特别是在unix/linux下,我没有环境,制作mod_webapp.so没有自己作过。具体方法,自己去找吧。

[@more@]

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

java工程配置

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

java工程配置

1、 安装TOMCAT最新版本是5.0.29(http://jakarta.apache.org/site/binindex.cgi)如果在WINDOWS下它可以自动找到你的JDK或者set JAVA_HOME=c:/jdk在LINUX下
2023-06-03

怎么配置Java的工作环境

这篇文章主要介绍“怎么配置Java的工作环境”,在日常操作中,相信很多人在怎么配置Java的工作环境问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么配置Java的工作环境”的疑惑有所帮助!接下来,请跟着小编
2023-06-03

vscode如何配置创建Node.js工程

这篇文章主要介绍“vscode如何配置创建Node.js工程”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vscode如何配置创建Node.js工程”文章能帮助大家解决问题。下载VSCode首先,您
2023-07-05

java 环境配置(详细教程)

文章目录 前言一、jdk 下载二、windows1、jdk 安装2、环境变量的配置2.1 Java_Home 配置2.2 Path 配置2.3 CLASSPATH 配置 3、检测是否配置成功 前言 java 环境配置
2023-08-16

Windows下Java环境配置教程

✨博客主页: XIN-XIANG荣 ✨系列专栏:【Java SE】 ✨一句短话: 难在坚持,贵在坚持,成在坚持! ✨博客说明: 尽己所能,把每一篇博客写好,帮助自己熟悉所学知识,也希望自己的这些内容可以帮助到一些在学习路上的伙伴,文章中
2023-08-21

Linux进程管理工具supervisor安装配置教程

环境:CentOS 7官方文档:http://supervisord.org/ 安装# yum install -y epel-release # yum install -y supervisor启动# supervisord -c /e
2022-06-03

java多线程参数如何配置

在Java中,可以通过设置以下参数来配置多线程:线程数(Thread Count):可以设置同时运行的线程数量。可以根据系统的处理能力和任务的性质来设置线程数。可以通过使用线程池来管理线程的数量。线程优先级(Thread Priority)
java多线程参数如何配置
2024-02-29

java怎么实现用户随意配置工作流

用户可以通过以下几种方式来实现工作流的随意配置:1. 使用流程定义语言:用户可以使用流程定义语言(如BPMN)来定义工作流程。这些语言提供了一套规范,用户可以根据自己的需求来进行配置和定义工作流程。通过这种方式,用户可以灵活地配置不同的节点
2023-08-26

java如何实现用户随意配置工作流

Java可以使用各种工作流引擎来实现用户随意配置工作流。以下是一个使用Activiti工作流引擎实现用户随意配置工作流的示例:1. 引入Activiti依赖:```xmlorg.activitiactiviti-engine7.2.0```
2023-08-24

Linux 进程管理工具之Supervisor安装配置

目录前言安装生成配置配置文件参数说明配置管理进程启动服务控制进程交互终端bash终端开机启动服务前言 Supervisor 是用 python 开发的一个 client/server 服务,是linux/Unix系统下的一个进程管理工具,不
2023-05-12

maven工程配置私库的方法是什么

要配置Maven工程使用私库,你需要在Maven的settings.xml文件中添加私库的配置信息。以下是配置私库的步骤:找到Maven安装目录下的conf文件夹下的settings.xml文件。在标签内添加标签,如下所示:私库ID私库U
2023-10-23

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录