技术标签: exception java string import classloader javaSe properties
篇章一:Loading Properties from XML
XML 属性文档具有以下 DOCTYPE 声明: <!DOCTYPE properties SYSTEM "http://java.sun.com/dtd/properties.dtd"> 注意,导入或导出属性时不 访问系统 URI (http://java.sun.com/dtd/properties.dtd);该系统 URI 仅作为一个惟一标识 DTD 的字符串:
下面运用loadFromXML(InputStream is)读取xml:
下面运用storeToXML(OutputStream os, String comment)方法来创建xml:
输出打印的结果为:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE properties SYSTEM "http://java.sun.com/dtd/properties.dtd">
<properties>
<comment>Rhyme</comment>
<entry key="seven-eight">lay them straight</entry>
<entry key="five-six">pick up sticks</entry>
<entry key="nine-ten">a big, fat hen</entry>
<entry key="three-four">shut the door</entry>
<entry key="one-two">buckle my shoe</entry>
</properties>
为什么会选择把properties和xml关联起来?
J2SE1.5以前的版本要求直接使用XML解析器来装载配置文件并存储设置。虽然这并非是一件困难的事情,并且解析器是平台的标准部分,但是额外的工作总是有点让人烦。最近更新的java.util.Properties类现在提供了一种为程序装载和存储设置的更容易的方法:loadFromXML(InputStream is)和storeToXML(OutputStream os, String comment)方法。使用 XML 文件还是使用老式的 a=b 类型的文件完全取决于您自己。老式文件从内存的角度看肯定是轻量级的。不过,由于 XML 的普遍使用,人们会期望 XML 格式流行起来,因为它已经被广泛使用了,只不过没有用到 Properties 对象。
不过在我看来properties同xml一样,引用API中的一句话:“它将资源包中大部分(如果不是全部)特定于语言环境的信息隔离开来。”,让我们可以轻松的进行修改及动态载入。
篇章二:更好理解它的方法
在开始这一篇章的讲解之前,我们先提一下两个类:
FileInputStream类:一个文件字节输入流,从中可以读出一个字节或一批字节
FileOutputStream类:一个文件字节输出流,可向流中写一个字节或一批字节
第一个方法:public void load(InputStream inStream) throws IOException从输入流中读取属性列表(键和元素对)。
第二个方法:public void store(OutputStream out,String comments)throws IOException将load方法读取到的属性列表写入out流中。这里的comments是注释
下面我们用代码来说明:
这里我们已经创建了两个properties文件:
文件1:
#test.properties
1=a
2=b
3=c
文件二:
#temp.test.properties
today=Monday
tomorrow=Tuesday
下面我们将就Store方法进行讨论
演示代码的结果是test.properties中的内容不变
而temp.properties中的内容如下:
#Update '2' value
#Sun Dec 02 00:16:31 CST 2007
3=c
2=w
1=a
我们可以发现当我们得到test.properties的属性列表后并调用setProperty对属性列表做出修改后得到的新的属性列表覆盖了temp.properties的内容。输入顺序正如api文档所述:如果 comments 变量非 null,则首先将 ASCII # 字符、注释字符串和一个行分隔符写入输出流。因此,该 comments 可用作一个标识注释。接下来总是写入一个注释行,该行包括一个 ASCII # 字符、当前的日期和时间(就好像使用 Date 的 toString 方法获取当前时间一样)和一个由 Writer 生成的行分隔符。然后将此 Properties 表中的所有项写入 out,一次一行。
如果只想在temp.properties的后面添加而不希望覆盖 ,我们只需这样写new FileOutputStream(String name,true)即可。
下面我们将写一个读properties的模块:
篇章3:如何解决中文乱码的问题
如果你的properties文件中含有中文,在不做任何处理的情况下你得到的将是一连串的问号。在那一步中产生了这一问题呢?在API中我们可以在load方法中阅读这一段:假定该流使用 ISO 8859-1 字符编码;也就是每个字节是一个 Latin1 字符。对于非 Latin1 的字符和某些特殊字符,可以使用与字符和字符串字面值所用的类似转义序列。
也就是说我们要把汉字转换为/uXXXX。
如何做到这一点,我这里有两个办法:
办法一:使用native2ascii 命令(具体用法csdn上可以搜到很多)。
办法二:重写native2ascii命令
对于办法二,我重写了一个模块,基本实现native2ascii的转义功能:
在写这个模块之前我使用的是这个模块当然这个模块经常被用来处理jsp的中文字符问题
代码如下:
篇章4:读取Properties文件三种方法
1。使用java.util.Properties类的load()方法
示例:InputStream in=new BufferedInputStream(new FileInputStream(name));
或者 InputStream in=JProperties.class.getResourceAsStream(name);
或者 InputStream in=JProperties.class.getClassLoader().getResourceAsStream(name);
或者 InputStreamin=ClassLoader.getSystemResourceAsStream(name);
然后:
Properties p=new Properties();
p.load(in);
2。使用java.util.ResourceBundle类的getBundle()方法
示例:ResourceBundlerb=ResourceBundle.getBundle(name,Locale.getDefault());
3。使用java.util.PropertyResourceBundle类的构造函数
示例:InputStream in=new BufferedInputStream(new FileInputStream(name));
ResourceBundler b=new PropertyResourceBundle(in);
补充:
Servlet中可以使用javax.servlet.ServletContext的getResourceAsStream()方法
示例:InputStreamin=context.getResourceAsStream(path);
Properties p=new Properties();
p.load(in);
篇章五:最后的模块——对properites值的修改
这段代码是极其有意义的,它非常全面的提供了Properties的修改操作,同时删除了重复的键值。
引用自: http://blog.csdn.net/busaudio/archive/2007/12/02/1911449.aspx 作者:RayAivin
Java读取properties文件
|
Properties 类已不是新东西了,它在 Java 编程的早期就有了,并且几乎没有什么变化。J2SE 的 Tiger 版本增强了这个类,不仅可以用它在单独一行中指定用等号分隔的多个键-值对,还可以用XML 文件装载和保存这些键-值对。在 驯服 Tiger的这一期文章中,John Zukowski 展示了如何驾驭这匹新一代的“役马”。请在本文对应的讨论论坛上与作者及其他读者分享您对本文的想法(您也可以单击文章顶部或底部的 讨论来访问该论坛)。
J2SE 1.5 以前的版本要求直接使用 XML 解析器来装载配置文件并存储设置。虽然这并非是一件困难的事情,并且解析器是平台的标准部分,但是额外的工作总是有点让人烦。最近更新的 java.util.Properties 类现在提供了一种为程序装载和存储设置的更容易的方法:
loadFromXML(InputStream is) 和storeToXML(OutputStream os, String comment) 方法。
Properties 基本知识
如果不熟悉 java.util.Properties 类,那么现在告诉您它是用来在一个文件中存储键-值对的,其中键和值是用等号分隔的,如清单 1 所示。
清单 1. 一组属性示例
foo=bar
fu=baz
将清单 1 装载到 Properties 对象中后,您就可以找到两个键( foo 和 fu )和两个值( foo 的 bar 和 fu 的 baz )了。这个类支持带 /u 的嵌入 Unicode 字符串,但是这里重要的是每一项内容都当作 String 。
清单 2 显示了如何装载属性文件并列出它当前的一组键和值。只需传递这个文件的 InputStream 给 load() 方法,就会将每一个键-值对添加到 Properties 实例中。然后用 list() 列出所有属性或者用 getProperty() 获取单独的属性。
清单 2. 装载属性
import java.util.*;
import java.io.*;
public class LoadSample {
public static void main(String args[]) throws Exception {
Properties prop = new Properties();
FileInputStream fis =
new FileInputStream("sample.properties");
prop.load(fis);
prop.list(System.out);
System.out.println("/nThe foo property: " +
prop.getProperty("foo"));
}
}
运行 LoadSample 程序生成如清单 3 所示的输出。注意 list() 方法的输出中键-值对的顺序与它们在输入文件中的顺序不一样。 Properties 类在一个散列表(hashtable,事实上是一个 Hashtable 子类)中储存一组键-值对,所以不能保证顺序。
清单 3 . LoadSample 的输出
-- listing properties --
fu=baz
foo=bar
The foo property: bar
XML 属性文件
这里没有什么新内 容。 Properties 类总是这样工作的。不过,新的地方是从一个 XML 文件中装载一组属性。它的 DTD 如清单 4 所示。
清单 4. 属性 DTD
<?xml version="1.0" encoding="UTF-8"?>
<!-- DTD for properties -->
<!ELEMENT properties ( comment?, entry* ) >
<!ATTLIST properties version CDATA #FIXED "1.0">
<!ELEMENT comment (#PCDATA) >
<!ELEMENT entry (#PCDATA) >
<!ATTLIST entry key CDATA #REQUIRED>
如果不想细读 XML DTD,那么可以告诉您它其实就是说在外围 <properties> 标签中包装的是一个 <comment> 标签,后面是任意数量的 <entry> 标签。对每一个 <entry> 标签,有一个键属性,输入的内容就是它的值。清单 5 显示了 清单 1中的属性文件的 XML 版本是什么样子的。
清单 5. XML 版本的属性文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE properties SYSTEM "http://java.sun.com/dtd/properties.dtd ">
<properties>
<comment>Hi</comment>
<entry key="foo">bar</entry>
<entry key="fu">baz</entry>
</properties>
如果清单 6 所示,读取 XML 版本的 Properties 文件与读取老格式的文件没什么不同。
清单 6. 读取 XML Properties 文件
import java.util.*;
import java.io.*;
public class LoadSampleXML {
public static void main(String args[]) throws Exception {
Properties prop = new Properties();
FileInputStream fis =
new FileInputStream("sampleprops.xml");
prop.loadFromXML(fis);
prop.list(System.out);
System.out.println("/nThe foo property: " +
prop.getProperty("foo"));
}
}
关于资源绑定的说明
虽然 java.util.Properties 类现在除了支持键-值对,还支持属性文件作为 XML 文件,不幸的是,没有内置的选项可以将 ResourceBundle 作为一个 XML 文件处理。是的, PropertyResourceBundle 不使用 Properties 对象来装载绑定,不过装载方法的使用是硬编码到类中的,而不使用较新的 loadFromXML() 方法。
运行清单 6 中的程序产生与原来的程序相同的输出,如 清单 2所示。
保存 XML 属性
新的 Properties 还有一个功能是将属性存储到 XML 格式的文件中。虽然 store() 方法仍然会创建一个类似 清单 1 所示的文件,但是现在可以用新的 storeToXML() 方法创建如 清单 5 所示的文件。只要传递一个 OutputStream 和一个用于注释的 String 就可以了。清单 7 展示了新的 storeToXML() 方法。
清单 7. 将 Properties 存储为 XML 文件
import java.util.*;
import java.io.*;
public class StoreXML {
public static void main(String args[]) throws Exception {
Properties prop = new Properties();
prop.setProperty("one-two", "buckle my shoe");
prop.setProperty("three-four", "shut the door");
prop.setProperty("five-six", "pick up sticks");
prop.setProperty("seven-eight", "lay them straight");
prop.setProperty("nine-ten", "a big, fat hen");
FileOutputStream fos =
new FileOutputStream("rhyme.xml");
prop.storeToXML(fos, "Rhyme");
fos.close();
}
}
运行清单 7 中的程序产生的输出如清单 8 所示。
清单 8. 存储的 XML 文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE properties SYSTEM "http://java.sun.com/dtd/properties.dtd ">
<properties>
<comment>Rhyme</comment>
<entry key="seven-eight">lay them straight</entry>
<entry key="five-six">pick up sticks</entry>
<entry key="nine-ten">a big, fat hen</entry>
<entry key="three-four">shut the door</entry>
<entry key="one-two">buckle my shoe</entry>
</properties>
结束语
使用 XML 文件还是使用老式的 a=b 类型的文件完全取决于您自己。老式文件从内存的角度看肯定是轻量级的。不过,由于 XML 的普遍使用,人们会期望 XML 格式流行起来,因为它已经被广泛使用了,只不过没有用到 Properties 对象。选择完全在您。分析软件包 private XMLUtils 类的源代码以获得关于所使用的 XML 解析的更多信息。
PTest.java
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;
/**
* 实现properties文件的读取
* @author bbflyerwww
* @date 2006-08-02
*/
public class PTest {
public static void main(String[] args) {
try {
long start = System.currentTimeMillis();
InputStream is = new FileInputStream("conf.properties");
Properties p = new Properties();
p.load(is);
is.close();
System.out.println("SIZE : " + p.size());
System.out.println("homepage : " + p.getProperty("homepage"));
System.out.println("author : " + p.getProperty("author"));
&nbp; System.out.println("school : " + p.getProperty("school"));
System.out.println("date : " + p.getProperty("date"));
long end = System.currentTimeMillis();
System.out.println("Cost : " + (end - start));
} catch (IOException ioe) {
ioe.printStackTrace();
}
}
}
conf.properties
# Configuration file
homepage = http://hi.baidu.com/bbflyerwww
author = bbflyerwww
school = WuHan University
date = 2006-08-02
Result
SIZE:4
homepage : http://hi.baidu.com/bbflyerwww
author : bbflyerwww
school : WuHan University
date : 2006-08-02
Cost : 0
========================================================================
package com.adrop.util;
import java.io.*;
import java.util.Properties;
import javax.servlet.http.*;
import javax.servlet.*;
import javax.servlet.jsp.*;
public class PropertiesUtil {
private String fileName;
private Properties p;
private FileInputStream in;
private FileOutputStream out;
/**
* 根据传进的文件名载入文件
* @param fileName String
*/
public PropertiesUtil(String fileName) {
this.fileName=fileName;
File file = new File(fileName);
try {
in = new FileInputStream(file);
p = new Properties();
// 载入文件
p.load(in);
in.close();
}
catch (FileNotFoundException e) {
System.err.println(" 配置文件 config.properties 找不到!! ");
e.printStackTrace();
}
catch (Exception e) {
System.err.println(" 读取配置文件 config.properties 错误!! ");
e.printStackTrace();
}
}
/**
* 配置文件一律为 config.propertities , 并且统一放在 web应用的根目录下。
* @return String
*/
public static String getConfigFile(HttpServlet hs) {
return getConfigFile(hs,"config.properties");
}
/**
* 在 servlet 中使用 , 直接用 this 作为参数 ,HttpServlet 类型
* 根据配置文件名从当前 web 应用的根目录下找出配置文件
* @param hs HttpServlet
* @param configFileName String 配置文件名字
* @return String
*/
public static String getConfigFile(HttpServlet hs, String configFileName) {
String configFile = "";
ServletContext sc = hs.getServletContext();
configFile = sc.getRealPath("/" + configFileName);
if (configFile == null || configFile.equals("")) {
configFile = "/" + configFileName;
}
return configFile;
}
/**
* jsp 中用 pageContext 作参数
* @param hs PageContext
* @param configFileName String 配置文件名字
* @return String
*/
public static String getConfigFile(PageContext hs, String configFileName) {
String configFile = "";
ServletContext sc = hs.getServletContext();
configFile = sc.getRealPath("/" + configFileName);
if (configFile == null || configFile.equals("")) {
configFile = "/" + configFileName;
}
return configFile;
}
/**
* 列出所有的配置文件内 容<
/span>
*/
public void list() {
p.list(System.out);
}
/**
* 指定配置项名称,返回配置 值
* @param itemName String
* @return String
*/
public String getValue(String itemName){
return p.getProperty(itemName);
}
/**
* 指定配置项名称和默认值, 返回配置值
* @param itemName String
* @param defaultValue String
* @return String
*/
public String getValue(String itemName,
String defaultValue){
return p.getProperty(itemName,defaultValue);
}
/**
* 设置配置项名称及其值
* @param itemName String
* @param value String
*/
public void setValue(String itemName,String value){
p.setProperty(itemName,value);
return;
}
/**
* 保存配置文件,指定文件名 和抬头描述
* @param fileName String
* @param description String
* @throws Exception
*/
public void saveFile(String fileName,String description)throws Exception{
try {
File f=new File(fileName);
out
= new FileOutputStream(f);
p.store(out, description);// 保存文件
out.close();
}
t"> catch (IOException ex) {
throw new Exception
(" 无法保存指 定的配置文件 :"+fileName);
}
}
/**
* 保存配置文件,指定文件名
* @param fileName String
* @throws Exception
*/
public void saveFile(String fileName)
throws Exception {
saveFile(fileName,"");
}
/**
* 保存配置文件,采用原文件 名
* @throws Exception
*/
public void saveFile() throws Exception {
if(fileName.length()==0)
throw new Exception
(" 需指定保存 的配置文件名 ");
saveFile(fileName);
}
/**
* 删除一个属性
* @param value String
*/
public void deleteValue(String value){
p.remove(value);
}
/**
* main method for test
* @param args String[]
*/
public static void main(String[] args) {
String file = "f://p.properties";
PropertiesUtil pu = new PropertiesUtil(file);
pu.list();
}
}
g="0">
Re:用java从properties配置文件里面读数据 |
[ 2009-10-27 10:44:00 | By: 访客M62Tl8(游客) ] |
学习了,呵呵,谢谢 |
个人主页 | 引用 | 返 回 | 删除 | 回复 |
|
Re:用java从properties配置文件里面读数据 |
[ 2007-12-18 20:49:00 | By: 张森的测试用户 ] |
代码实例
package configuration;public class Configuration
...{
private Properties propertie;
private FileInputStream inputFile;
private FileOutputStream outputFile;
/** *//**
* 初始化Configuration类
*/
public Configuration()
...{
propertie = new Properties();
}
/** *//**
* 初始化Configuration类
* @param filePath 要读取的配置文件的路径+名称
*/
public Configuration(String filePath)
...{
propertie = new Properties();
try ...{
inputFile = new FileInputStream(filePath);
propertie.load(inputFile);
inputFile.close();
} catch (FileNotFoundException ex) ...{
System.out.println("读取属性文件 --->失败!- 原因:文件路径错误或者文件不存在");
ex.printStackTrace();
} catch (IOException ex) ...{
System.out.println("装载文件--->失败!");
ex.printStackTrace();
}
}//end ReadConfigInfo(...)
以下为张森的测试用户的回复:
今天写了一个读取配置文件信息的程序如下(演示代码不 可用于工程 ):
java 代码
public class Config {
private static Properties prop = new Properties();
static {
try {
//prop.load(Config.class.getResourceAsStream("../../config/config.properties"));
prop.load(Config.class.getResourceAsStream("../aa/config.properties"));
} catch (IOException e) {
System.out.println("文件不存在!");
e.printStackTrace();
}
}
public static String CONNECTION_TYPE = prop.getProperty("conn_type");
public static String CONNECTION_URL = prop.getProperty("conn_url");
public static String CONNECTION_USER = prop.getProperty("conn_user");
public static String CONNECTION_PWD = prop.getProperty("conn_pwd");
public static String CONNECTION_DRIVER = prop.getProperty("conn_driver");
public static String DB_CFG_URL = prop.getProperty("DB_CFG_URL");
public static String DB_CFG_USER = prop.getProperty("DB_CFG_USER");
public static String DB_CFG_PASSWORD = prop.getProperty("DB_CFG_PASSWORD");
}
html 代码
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<!--CTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"</sp-->>
<%@ page import="com.*" %>
<html>
<head>
<title>首页title>
head>
<body>
URL名:<%=Config.DB_CFG_URL%><br>
用户 名:<%=Config.DB_CFG_USER%><br>
密 码:<%=Config.DB_CFG_PASSWORD%>
body>
配置文件的路径如下:1、 WEB-INF----->config------->config.properties
2、WEB- INF------>classes----->aa----->config.properties
上面的程序可以 读到WEB-INF------>classes----->aa----->config.properties,但读不到WEB- INF----->config------->config.properties
另外一种实现方式:
java 代码
package com;
import java.io.*;
import java.util.Properties;
public class FileConfig
{
public Properties getFileProp()
{
Properties prop = new Properties();
try {
//File fClass = new File("applications/d btest/WEB-INF/config/config.properties");
File fClass = new File("webapps/dbtest/WEB-INF/config/config.properties");
FileInputStream fis = new FileInputStream(fClass);
prop.load(fis);
} catch (IOException e) {
System.out.println("文件不存在!");
e.printStackTrace();
}
if(prop != null)
return prop;
else
return null;
}
}
html代码
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@ page import="com.FileConfig" %>
<!--CTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"</sp-->>
<html>
<head>
<title>首页title>
head>
<body>
<%
FileConfig fc = new FileConfig();
Properties prop = fc.getFileProp();
%>
body>
<%=prop.getProperty("DB_CFG_PASSWORD")%>
<%=prop.getProperty("DB_CFG_USER")%>
<%=prop.getProperty("DB_CFG_URL")%>
第二种方法解决了不能读取 classes上次目录下文件内容的问题。它认的是容器的根目录如:tomcat就是webapps是第一级录,而在weblogic下则是 applications。
如果您刚刚开始接触网页设计,是不是经常发生这样的问题呢?做好的网页在自己机器上可以正常浏览,而把页面传 到服务器上就总是出现看不到图片,css样式表失效等错误。这种情况下多半是由于你使用了错误的路径,在应该使用相对路径的地方使用了绝对路径,导致浏览 器无法在指定的位置打开指定的文件。
以下为张森的测试用户的回复:
今天写了一个读取配置文件信息的程序如下(演示代码不 可用于工程 ):
java 代码
public class Config {
private static Properties prop = new Properties();
static {
try {
//prop.load(Config.class.getResourceAsStream("../../config/config.properties"));
prop.load(Config.class.getResourceAsStream("../aa/config.properties"));
} catch (IOException e) {
System.out.println("文件不存在!");
e.printStackTrace();
}
}
public static String CONNECTION_TYPE = prop.getProperty("conn_type");
public static String CONNECTION_URL = prop.getProperty("conn_url");
public static String CONNECTION_USER = prop.getProperty("conn_user");
public static String CONNECTION_PWD = prop.getProperty("conn_pwd");
public static String CONNECTION_DRIVER = prop.getProperty("conn_driver");
public static String DB_CFG_URL = prop.getProperty("DB_CFG_URL");
public static String DB_CFG_USER = prop.getProperty("DB_CFG_USER");
public static String DB_CFG_PASSWORD = prop.getProperty("DB_CFG_PASSWORD");
}
html 代码
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<!--CTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"</sp-->>
<%@ page import="com.*" %>
<html>
<head>
<title>首页title>
head>
<body>
URL名:<%=Config.DB_CFG_URL%><br>
用户 名:<%=Config.DB_CFG_USER%><br>
密 码:<%=Config.DB_CFG_PASSWORD%>
body>
配置文件的路径如下:1、 WEB-INF----->config------->config.properties
2、WEB- INF------>classes----->aa----->config.properties
上面的程序可以 读到WEB-INF------>classes----->aa----->config.properties,但读不到WEB- INF----->config------->config.properties
另外一种实现方式:
java 代码
package com;
import java.io.*;
import java.util.Properties;
public class FileConfig
{
public Properties getFileProp()
{
Properties prop = new Properties();
try {
//File fClass = new File("applications/dbtest/WEB-INF/config/config.properties");
File fClass = new File("webapps/dbtest/WEB-INF/config/config.properties");
FileInputStream fis = new FileInputStream(fClass);
prop.load(fis);
} catch (IOException e) {
System.out.println("文件不存在!");
e.printStackTrace();
}
if(prop != null)
return prop;
else
return null;
}
}
html代码
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@ page import="com.FileConfig" %>
<!--CTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"</sp-->>
<html>
<head>
<title>首页title>
head>
<body>
<%
FileConfig fc = new FileConfig();
Properties prop = fc.getFileProp();
%>
body>
<%=prop.getProperty("DB_CFG_PASSWORD")%>
<%=prop.getProperty("DB_CFG_USER")%>
<%=prop.getProperty("DB_CFG_URL")%>
第二种方法解决了不能读取 classes上次目录下文件内容的问题。它认的是容器的根目录如:tomcat就是webapps是第一级录,而在weblogic下则是 applications。
如果您刚刚开始接触网页设计,是不是经常发生这样的问题呢?做好的网页在自己机器上可以正常浏览,而把页面传 到服务器上就总是出现看不到图片,css样式表失效等错误。这种情况下多半是由于你使用了错误的路径,在应该使用相对路径的地方使用了绝对路径,导致浏览 器无法在指定的位置打开指定的文件。
以下为张森的测试用户的回复:
用java从properties配置文件里面读数据 -Servlet
第一步:配置文件
1. web.xml
<servlet>
<servlet-name>InitServlet</servlet-name>
<servlet-class>com.0734w.util.InitServlet</servlet-class>
<init-param>
<param-name>config</param-name>
<param-value>/WEB-INF/config.properties</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
2.config.properties
假 若在config.properties配置如下
app1.name=dog
app2.name=pig
3.在 Constants.java中定义
public final static String APP1NAME = "app1.name";
public final static String APP2NAME = "app2.name";
第二步:定义InitServlet
package com.0734w.util;
import java.io.IOException;
import java.io.InputStream;
import java.util.PropertyResourceBundle;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import org.apache.log4j.Logger;
import com.cpic.adapter.adapterapp.constant.Constants;
/**
* <p>Title:InitServlet.java</p>
* <p>Description:当应用起动时加载要读取的数据放入context中</p>
* @author spark 2005-12-26
* @version 1.0
*/
public class InitServlet extends HttpServlet {
private Logger logger;
public void init() throws ServletException{
super.init();
ServletContext context = getServletContext();
context.setAttribute(Constants.ADAPTER_INIT_STATUS,Boolean.FALSE);
//initialize proxy configuration
initAdapter();
context.setAttribute(Constants.ADAPTER_INIT_STATUS,Boolean.TRUE);
logger.info("initAdapter initialized successfully");
}
/**
* <p>Description:加载和设置数据</p>
* @throws ServletException
* spark 2005-12-26
*/
private void initAdapter() throws ServletException{
ServletContext context = getServletContext();
String configFile = getInitParameter("config");
if (configFile == null) {
String errMsg="Initialize Adapter configuration config file is not set in web.xml.";
logger.error(errMsg);
ServletException e = new ServletException(errMsg);
throw e;
}
InputStream in;
PropertyResourceBundle configBundle;
try {
in = this.getServletContext().getResourceAsStream(configFile);
configBundle = new PropertyResourceBundle(in);
//需要读取的数据每一个数据都要从这里 定义 context.setAttribute(Constants.APP1NAME,configBundle.getString(Constants.APP1NAME));
context.setAttribute(Constants.APP2NAME,configBundle.getString(Constants..APP2NAME));
} catch (IOException e) {
String errMsg = "Initialize adapter config.properties failed.";
logger.error(errMsg);
ServletException e1 = new ServletException(errMsg);
throw e1;
}
catch (Exception e) {
String errMsg = "Initialize adapter config.properties failed.";
logger.error(errMsg);
ServletException e1 = new ServletException(errMsg);
throw e1;
}
}
}
第三 步,在应用利用:<
br />在servlet中如下: ServletContext context = getServletContext(); ( String) context.getAttribute(Constants.APP1NAME) 在STRUTS的ACTION中如下: ServletContext context = request.getSession().getServletContext(); (String) context.getAttribute(Constants.APP1NAME); 以下为张森的测试用户的回复: 使用J2SE API读取Properties文件的六种方法 1。 使用java.util.Properties类的load()方法 示例: InputStream in = lnew BufferedInputStream(new FileInputStream(name)); Properties p = new Properties(); p.load(in); 2。使用java.util.ResourceBundle类的 getBundle()方法 示例: ResourceBundle rb = ResourceBundle.getBundle(name, Locale.getDefault()); 3。使用java.util.PropertyResourceBundle类的构造函数 示 例: InputStream in = new BufferedInputStream(new FileInputStream(name)); ResourceBundle rb = new PropertyResourceBundle(in); 4。使用class变量的 getResourceAsStream()方法 示例: InputStream in = JProperties.class.getResourceAsStream(name); Properties p = new Properties(); p.load(in); 5。使用class.getClassLoader()所得到的 java.lang.ClassLoader的getResourceAsStream()方法 示例: InputStream in = JProperties.class.getClassLoader().getResourceAsStream(name); Properties p = new Properties(); p.load(in); 6。使用java.lang.ClassLoader类的 getSystemResourceAsStream()静态方法 示例: InputStream in = ClassLoader.getSystemResourceAsStream(name); Properties p = new Properties(); p.load(in); 补充 Servlet中可以使用 javax.servlet.ServletContext的getResourceAsStream()方法 示例:InputStream in = context.getResourceAsStream(path); Properties p = new Properties(); p.load(in); |
文章浏览阅读6.6k次,点赞9次,收藏29次。mapstruct 实体转换及List转换,@Mapper注解转换 开发中,我们经常需要将PO转DTO、DTO转PO等一些实体间的转换。比较出名的有BeanUtil 和ModelMapper等,它们使用简单,但是在稍显复杂的业务场景下力不从心。MapStruct这个插件可以用来处理domin实体类与model类的属性映射,可配置性强。只需要定义一个 Mapper 接口,MapStruct 就会自动实现这个映射接口,避免了复杂繁琐的映射实现。MapStruct官网地址:http://mapstruct.o_@mapping list
文章浏览阅读265次。获取远程服务器上的盘符文件夹 内容精选换一换已成功登录Java性能分析。待安装Guardian的服务器已开启sshd。待安装Guardian的服务器已安装JRE,JRE版本要求为Huawei JDK 8或者Open JDK 8/11。Java性能分析优先选用非交互shell(non-interactive shell)中的JAVA_HOME环境变量所指定的JRE版本运行Guardi已成功登录Jav..._远程读取磁盘
文章浏览阅读1.5w次,点赞2次,收藏18次。当β = 0时,Swish变为线性函数f(x)=x/2β → ∞, σ(x)=(1+exp(−x))−1σ(x)=(1+exp(−x))−1为0或1. Swish变为ReLU: f(x)=2max(0,x)所以Swish函数可以看做是介于线性函数与ReLU函数之间的平滑函数. beta是个常数或者可以训练的参数。其具有无上界有下界、平滑、非单调的特性。其在模型效果上优于ReLU。ha..._swish和hardswish
文章浏览阅读153次。《ACM竞赛-C/C++入门》 C语言-2 毕业于清华大学,曾担任Googl..._,c++ 语言本身比较难学,语法特性很多,这里推荐一个acm大佬的免费课程,可以试听下,
文章浏览阅读4.7k次,点赞3次,收藏8次。此问题可导致不可使用pip解决方法:cmd 中输入:python -m ensurepipScripts文件夹下就出现 pip的exe 文件,配置好环境变量(把本路径加到path下),pip就可以使用了_python scripts 是空的
文章浏览阅读2.4k次。实习第二天Lua直接上手体验,各种嵌套的内容像html实际代码体验类似c上手luastudio,增加断点调试,修改逻辑发现bug最近登录角色level显示错误创建自定义位置解决项目,导入项目文件夹。添加现有项Unity此时没有运行代码,调试窗口附加到进程,启动调试右侧会显示调用方法。 实习第三天涉及问题 :UI错位问题 其中宝箱尺..._luastudio
文章浏览阅读3.1k次。//几分钟前后 this.addMinutes = function (v, n) { v = toDate(v); if (v) { v = new Date(v.valueOf()); v...._js addminutes
文章浏览阅读4.5k次。问题:为以后碰到这个问题的朋友们填一个坑,今天在学习二层板天线布线的最后时需要铺铜,所以需要将Top Layer的铜皮形状复制到Botto Layer中去,铜皮不会自动更新,下图是教程里的图片(能repour polygon):经过百度后发现是PCB Editor设置有问题!具体设置步骤如下:1.打开DXP中的Preferences。2.将PCB Editor中的General,然后勾选..._repour polygon after
文章浏览阅读6.7k次,点赞7次,收藏47次。利用双重for循环控制输入二维数组,再将 a[ i ][ i ]累加后输出。求一个3 * 3矩阵对角线元素之和。_c语言求一个3×3矩阵对角线元素之和。
文章浏览阅读633次。(1)从键盘循环录入录入一个字符串,输入"end"表示结束(2)将字符串中大写字母变成小写字母,小写字母变成大写字母,其它字符用"*"代替,并统计字母的个数举例:键盘录入:Hello12345World输出结果:hELLO*****wORLD总共10个字母package test7_2;import java.util.Scanner;public class Demo02 { public static void main(String[] args) { while(true_换行不表示结束符,做字符统计,但用一个特殊的字符串“#end”来表示结束符,该结束
文章浏览阅读4.7k次。 1. 1px 边框变粗问题截图如下(iPhone 6截图):如果我们把上图与我们手机系统上的 1px 边框进行对比,如下图:我们会发现,上面两个上下线条,下线条的粗细才是正确的,上线条就显得有点粗了。但是上线条我们是用纯正的 1px border生成的,而下线条我们实际是采用transform压缩了1px高度的一半模拟实现的,也就相当于 0.5px 的高度了。为什么会这样..._分割线1px
文章浏览阅读143次。在过去几年的DevOps的浪潮中,自动化、持续集成这两个概念早已深入人心(互联网技术人)。比尔盖茨先生曾经都说过:“任何技术在一个业务中使用的第一条规则就是,将自动化应用到一个高效的操作上将会放大高效。第二条就是自动化应用到一个低效操作上,则放大了低效率。”自动化部署也逐渐成为各中小型企业追求的方向,那么,今天民工哥就自动化部署的概述、自动化部署的工具、自动化部署的流程、自动化部署实践等4个方面,..._git 自动发布工具