设置方法参考:
打开eclipse,打开window—>preference。
General ->Startup and Shutdown,这个时候在右侧就显示出了eclipse启动时加载的模块,可以根据自己的实际情况勾选掉一些不需要的加载项。
加载项中以Eclipse EASIE 打头的是指eclipse支持的服务器,一般只选择自己项目中需要的服务器就可以了,别的都可以勾选掉。
设置好后点击apply—>OK,关闭preference。下次启动生效。
如果需要添加启动加载的模块,按照同样步骤勾选相应的加载项就可以了。
看了楼上的发言,你有资格说别人傻吗?看清楚楼主的问题好不好!楼主的意思是直接在java程序中配置实现,而不是像你那么傻的手动去实现!转载两篇文章,结合起来可以实现java应用程序开机自动启动
可能也有别的好方法,这只是其中的一种
思路就是将java应用程序打包成.jar文件,然后转成.exe,通过修改注册表来增加删除启动项,即将安装后的.exe执行文件添加到注册表中;
首先将java应用程序打包成.jar文件,可以利用如下代码找到.jar文件的绝对路径,即也可以找到安装后的.exe执行文件
转载:
对于Java程序,无论是未打包的还是打包的JAR或WAR文件,有时候都需要获取它运行所在目录信息,如何做到这一点呢?
在Java处理的文件系统中,目录的表示方式有两种:
(1)绝对目录,它以"/"为起始字符,代表从根目录下开始寻找给出的目录,如/c:/java
(2)相对路径,它以不带“/”的目录名表示,表示以当前Java程序正在运行的目录作为起始目录来寻找给出的目录。如java/classes。在相对路径中,有一些特定的字符,可以代表特的的目录,比如,“.”代表当前目录,“..”代表当前目录的上一级目录。在网上很多给出的例子中,就是利用"."作为目录名,构造File对象的实例,然后通过File对象的方法来获取当前程序运行的目录。
这种方法虽然简单,但有时不能正确的得出当前程序的运行目录。原因在于,运行Java程序不一定要进入到该程序的类文件或JAR文件所在的目录,只要在运行时指定了正确的类路径信息,就可以在任何目录中运行Java程序,此时利用这种方法只能得到发出运行命令时所在的目录信息。
从上面的分析可以看出,对于很多Java程序,尤其是WEB程序,利用当前路径的“.”表示法,都不能满足要求。那么怎样才能正确的得到运行目录信息呢?
在Web程序中,利用Servlet API可以获得一些路径信息,比如HttpServletRequest接口中定义的getRealPath方法,但类似这些方法都依赖于Servlet环境,不便于程序的单元测试。
本文提供了一种只使用Java标准API的路径探测方法,就是利用ClassLoader抽象类。
利用java.lang.Class的getClassLoader方法,可以获得给定类的ClassLoader实例,它的getResource方法可以获得当前类装载器中的资源的位置,我们可以利用类文件的名称作为要查找的资源,经过处理后就可获得当前Java程序的运行位置信息,其伪代码如下:
获得Class参数的所在的类名
取得该类所在的包名
将包名转换为路径
利用getResource得到当前的类文件所在URL
利用URL解析出当前Java程序所在的路径
具体代码如下:
java代码:
Java代码
/**-----------------------------------------------------------------------
*getAppPath需要一个当前程序使用的Java类的class属性参数,它可以返回打包过的
*Java可执行文件(jar,war)所处的系统目录名或非打包Java程序所处的目录
*@param cls为Class类型
*@return 返回值为该类所在的Java程序运行的目录
-------------------------------------------------------------------------*/
public static String getAppPath(Class cls){
//检查用户传入的参数是否为空
if(cls==null)
throw new java.lang.IllegalArgumentException("参数不能为空!")
ClassLoader loader=cls.getClassLoader()
//获得类的全名,包括包名
String clsName=cls.getName()+".class"
//获得传入参数所在的包
Package pack=cls.getPackage()
String path=""
//如果不是匿名包,将包名转化为路径
if(pack!=null){
String packName=pack.getName()
//此处简单判定是否是Java基础类库,防止用户传入JDK内置的类库
if(packName.startsWith("java.")||packName.startsWith("javax."))
throw new java.lang.IllegalArgumentException("不要传送系统类!")
//在类的名称中,去掉包名的部分,获得类的文件名
clsName=clsName.substring(packName.length()+1)
//判定包名是否是简单包名,如果是,则直接将包名转换为路径,
if(packName.indexOf(".")<0) path=packName+"/"
else{//否则按照包名的组成部分,将包名转换为路径
int start=0,end=0
end=packName.indexOf(".")
while(end!=-1){
path=path+packName.substring(start,end)+"/"
start=end+1
end=packName.indexOf(".",start)
}
path=path+packName.substring(start)+"/"
}
}
//调用ClassLoader的getResource方法,传入包含路径信息的类文件名
java.net.URL url =loader.getResource(path+clsName)
//从URL对象中获取路径信息
String realPath=url.getPath()
//去掉路径信息中的协议名"file:"
int pos=realPath.indexOf("file:")
if(pos>-1) realPath=realPath.substring(pos+5)
//去掉路径信息最后包含类文件信息的部分,得到类所在的路径
pos=realPath.indexOf(path+clsName)
realPath=realPath.substring(0,pos-1)
//如果类文件被打包到JAR等文件中时,去掉对应的JAR等打包文件名
if(realPath.endsWith("!"))
realPath=realPath.substring(0,realPath.lastIndexOf("/"))
/*------------------------------------------------------------
ClassLoader的getResource方法使用了utf-8对路径信息进行了编码,当路径
中存在中文和空格时,他会对这些字符进行转换,这样,得到的往往不是我们想要
的真实路径,在此,调用了URLDecoder的decode方法进行解码,以便得到原始的
中文及空格路径
-------------------------------------------------------------*/
try{
realPath=java.net.URLDecoder.decode(realPath,"utf-8")
}catch(Exception e){throw new RuntimeException(e)}
return realPath
}//getAppPath定义结束
//-----------------------------------------------------------------
该方法既可以用于JAR或WAR文件,也可以用于非JAR文件。但要注意以下2点:
不要传递系统的类,作为getAppPath的参数,如java.lang.String.class,当然,也不要传递那些已经位于JDK中的那些类,比如xml相关的一些类等等。
要传递应该是程序中主要的运行类,不要传递程序中的支持类库中的类文件,也就是那些第三方的类库中的类文件,否则得到的将是那些类库的位置。
然后可以通过修改注册表来增加开机启动项:
转载:
需要修改的注册表项
[HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Run] 开机自动运行程序
[HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\RunOnce] 开机自动运行程序 且 仅运行一次
[HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\RunServices] 开机自动运行服务
JDK 从1.4开始提供 *** 作 Windows 的 API 是 Preferences,因为这个 API 也是跨平台的,所功能比较弱,在 Win32 下只能用来 *** 作 HKCU\Software\JavaSoft 和 HKLM\Software\JavaSoft 下及子节点的数据。
自由访问注册表其他键的值光用 Java 是做不到的,必然方案就是 JNI,这里我使用的是Windows Registry API Native Interface http://www.trustice.com/java/jnireg/index.shtml 下的 registry-3.1.3.zip(包含源代码)。可以利用它访问、修改、导出注册表项到文件等。解开 registry-3.1.3.zip,在 bin 目录中可以看到两个文件 ICE_JNIRegistry.dll 和 registry.jar,动态库就是本地代码实现。
com.ice.jni.registry.Registry.main() 就是 registry 的示例代码,动态库 ICE_JNIRegistry.dll 也是在这个类的静态块中被加载的,记得要把 ICE_JNIRegistry.dll 放在它能够被加载的位置上,比如你把 registry-3.1.3.zip 解压到 c:\registry-3.1.3,在命令行下你可以进入到这个目录中,并执行。
代码:
Java代码
package org.zh.ss.util
import com.ice.jni.registry.*
import java.text.SimpleDateFormat
/** *//**
* java *** 作注册表
* @author 李志远
*/
public class RegeditTool {
static SimpleDateFormat shortDateFormat = new SimpleDateFormat("yyyy-MM-dd")
/** *//** */
/** *//** Creates a new instance of test */
// 把信息存储到注册表HKEY_LOCAL_MACHINE下的某个节点的某一变量中,有则修改,无则创建
public static boolean setValue(String folder, String subKeyNode,
String subKeyName, String subKeyValue) {
try {
RegistryKey software = Registry.HKEY_LOCAL_MACHINE
.openSubKey(folder)
RegistryKey subKey = software.createSubKey(subKeyNode, "")
subKey
.setValue(new RegStringValue(subKey, subKeyName,
subKeyValue))
subKey.closeKey()
return true
} catch (NoSuchKeyException e) {
e.printStackTrace()
} catch (NoSuchValueException e) {
e.printStackTrace()
} catch (RegistryException e) {
e.printStackTrace()
}
return false
}
// 删除注册表中某节点下的某个变量
public static boolean deleteValue(String folder, String subKeyNode,
String subKeyName) {
try {
RegistryKey software = Registry.HKEY_LOCAL_MACHINE
.openSubKey(folder)
RegistryKey subKey = software.createSubKey(subKeyNode, "")
subKey.deleteValue(subKeyName)
subKey.closeKey()
return true
} catch (NoSuchKeyException e) {
System.out.println("NOsuchKey_delete")
} catch (NoSuchValueException e) {
System.out.println("NOsuchValue_delete")
} catch (RegistryException e) {
e.printStackTrace()
}
return false
}
// 删除注册表中某节点下的某节点
public static boolean deleteSubKey(String folder, String subKeyNode) {
try {
RegistryKey software = Registry.HKEY_LOCAL_MACHINE
.openSubKey(folder)
software.deleteSubKey(subKeyNode)
software.closeKey()
return true
} catch (NoSuchKeyException e) {
e.printStackTrace()
} catch (RegistryException e) {
e.printStackTrace()
}
return false
}
// 打开注册表项并读出相应的变量名的值
public static String getValue(String folder, String subKeyNode,
String subKeyName) {
String value = ""
try {
RegistryKey software = Registry.HKEY_LOCAL_MACHINE
.openSubKey(folder)
RegistryKey subKey = software.openSubKey(subKeyNode)
value = subKey.getStringValue(subKeyName)
subKey.closeKey()
} catch (NoSuchKeyException e) {
value = "NoSuchKey"
// e.printStackTrace()
} catch (NoSuchValueException e) {
value = "NoSuchValue"
// e.printStackTrace()
} catch (RegistryException e) {
e.printStackTrace()
}
return value
}
// 测试
public static void main(String[] args) {
setValue("SOFTWARE", "Microsoft\\Windows\\CurrentVersion\\Run", "test",
"C:\\1.exe")
}
}
这样,就可以在软件中添加,删除,修改开机启动项了
1、首先需要在linux服务器上配置java环境,如安装jdk+tomcat
2、配置完成jdk+tomcat环境后,需要把你的java项目复制到tomcat的webapps下
3、复制到tomcat的webapps后,重启tomcat,然后访问http://ip:8080/项目名,浏览验证java项目
4、安装jdk+tomcat环境如下:
1)下载JDK(下面分别是32位系统和64位系统下的版本)
http://download.oracle.com/otn-pub/java/jdk/7u9-b05/jdk-7u9-linux-i586.tar.gz?AuthParam=1350717577_c0836b48d7dc4cd4598cdd4f0d49e6f6 #32位
http://download.oracle.com/otn-pub/java/jdk/7u9-b05/jdk-7u9-linux-x64.rpm?AuthParam=1350717726_9b669eca29c07ddaaf6d8dc41e7a2684 #64位
# getconf LONG_BIT # 查看系统多少位
2) 安装JDK7.0版本
先卸载服务器自带的jdk软件包
# java -version #查看服务器是否安装过jdk
java version "1.6.0_17"
OpenJDK Runtime Environment (IcedTea6 1.7.4) (rhel-1.21.b17.el6-i386)
OpenJDK Client VM (build 14.0-b16, mixed mode)
# rpm -qa |grep gcj #查看服务器安装的jdk软件包信息
libgcj-4.4.4-13.el6.i686
java-1.5.0-gcj-1.5.0.0-29.1.el6.i686
# yum -y remove java-1.5.0-gcj-1.5.0.0-29.1.el6.i686 #卸载软件包
安装jdk7.0
解压配置安装
# mkdir -p /usr/lib/jvm
# tar zxvf jdk-7u9-linux-i586.tar.gz -C /usr/lib/jvm
# mv /usr/lib/jvm/jdk1.7.0_09 /usr/lib/jvm/java7
添加jdk7.0到系统环境变量
# cp /etc/profile /etc/profile.bak #备份
# vi /etc/profile #编辑,在最后添加下面的内容
export JAVA_HOME=/usr/lib/jvm/java7
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
export PATH=${JAVA_HOME}/bin:$PATH
# source /etc/profile #使配置文件立即生效
由于系统中可能会有默认的其他版本JDK,所以,为了将我们安装的JDK设置为默认JDK版本,还要进行如下工作。
update-alternatives --install /usr/bin/java java /usr/lib/jvm/java7/bin/java 300
update-alternatives --install /usr/bin/javac javac /usr/lib/jvm/java7/bin/javac 300
update-alternatives --install /usr/bin/jar jar /usr/lib/jvm/java7/bin/jar 300
update-alternatives --install /usr/bin/javah javah /usr/lib/jvm/java7/bin/javah 300
update-alternatives --install /usr/bin/javap javap /usr/lib/jvm/java7/bin/javap 300
执行下面命令,设置默认版本,此命令执行后,系统会列出当前存在的各种JDK版本,会提示你选择
# update-alternatives --config java
测试
# java -version # 测试是否成功
下载并启动tomcat
# cd /data 进入你放置的目录# wget http://mirrors.cnnic.cn/apache/tomcat/tomcat-7/v7.0.56/bin/apache-tomcat-7.0.56.tar.gz
# tar -zxv -f apache-tomcat-7.0.56.tar.gz
# mv apache-tomcat-7.0.56 /usr/local/tomcat7
# chmod 755 -R /usr/local/tomcat7/
# /usr/local/tomcat7/bin/startup.sh
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)