由于在学JSP的过程中会用到Oracle,所以我在自己的机器上装上了Oracle 10g,但是在安装使用过程中遇到两个问题。
1.OracleDBConsole服务不能启动,访问“http://机器名:1158/em”不能进入EM界面,系统事件查看器里面记录“Agent process exited abnormally during initialization.”
- 网上有很多这个问题的解决方案,我也试了不少,对我这么个Oracle菜鸟来说实在太痛苦了,因为自己不知道怎么解决,所以这个说法要试一试,那个说法也要试试,但是一直没解决,今天终于搞定了,下面给出我的情况的解决方法:
- 网上解决Oracle服务不能启动最多的做法是修改host文件,即%ORACLE HOME%\db_1\NETWORK\ADMIN\listener.ora文件,修改其中的HOST=内容,我也试了下,但是也没解决,今天我突然发现listener.ora文件中的HOST =XXX的XXX与我的机器名不一致,但是我自从安装oracle之后就没有改变过机器名,但是我还是照着网上的做法修改了HOST=机器名,重新启动OracleDBConsole服务,发现还是不能解决问题,后来我又撤销了修改,把机器名改成了HOST=XXX的XXX,启动服务,发现服务能正常启动,故障排除,后来我想了想可能是因为我在安装Oracle过程中选择的是高级安装模式,而在机器名中使用了默认的localhost而不是自己实际的机器名称,所以会出现这样的问题。
2.在打开EM登陆页面之后,用SYS登陆,发现首页有个错误,提示“java.lang.Exception: Exception in sending Request :: null”,继续上网寻找,在Oracle论坛上终于找到了解决方法:
- 打开$ORACLE_HOME/<global_db_name>_<db_sid>/sysman/config/emd.properties文件,在其中查找agentTZRegion将后面的GMT修改成你所在时区,比如说agentTZRegion=Asia/Shanghai,重新启动OracleDBConsole服务,OK!
- 关于时区的列表参考:10.2.0\db_1\sysman\admin\supportedtzs.lst
P.S 512Mb的机器跑Oracle 10g真痛苦!~
alex 工作学习 10g, oracle, 故障, 服务
为什么能通过property="*"的方式,将内容设置到Bean中,其根本原因是使用了Java的反射机制,根据传递参数的名称找到相应的方法,比如,参数名称为name,则自动找到setName方法。
- 原则:使用JavaBean自动设置内容时,一定要让参数名称与Bean中的属性名称一致,这样通过Java的命名规范,可以达到统一
- 当需要指定某个属性内容时候,可以在property中指定参数
- <jsp:setProperty name="sb" property="*"/> :自动匹配,开发中常采用这种做法
- <jsp:setProperty name="sb" property="name"/>:可以根据自己的需要设置需要的属性值
- <jsp:setProperty name="sb" property="name" param="password"/>:可以根据自己的需要,任意选择传递参数
- <jsp:setProperty name="sb" property="name" value="password"/>:根据用户的需要自己设置参数的值
JavaBean取得属性的方法:
- <jsp:getProperty name="sb" property="name"/>取得属性没有自动匹配
使用JavaBean的setProperty方法可以自动将传递过来的只有数字的字符串变为整形,之后将内容赋值给具体的属性 –>智能
JavaBean的属性范围:
- page范围:属性只在当前页有效,如果跳转其他页面,则需要重新实例化
- request范围:属性只保存在一次服务器跳转中,前提是使用<jsp:forward>跳转才行
- session范围:属性保存在一次会话中,可以任意方式连接其他页面,则此对象只实例化一次
- application范围:属性公有,此对象在整个服务器上只实例化一次。尽量少用因为application会占用资源
alex Java bean, Java, javabean, jsp, 属性, 范围
动态WEB的最大特点:可以操作数据库
- JSP是通过JDBC(Java DataBase Connectivity)技术操作数据库的
- 使用数据库之后可以发现,对数据的处理由数据库管理系统(DBMS)去完成,而程序只是将需要的数据进行显示
JDBC本身是JAVA连接数据库的一个标准,是JAVA操作数据库的方法,是SUN提供的,而微软操作数据库的方法是ODBC
JDBC 1.0:
- 分类:
- JDBC-ODBC Bridge(JDBC-ODBC桥接方式):因为性能较差,在开发中不采用
- JDBC-native Driver Bridge:驱动有个数据库生产厂家提供
- JDBC-network Bridge
- JDBC-ODBC:
- JDBC-ODBC是在JDK中由SUN本身开发出来的一套数据访问操作,在JDBC-ODBC桥接中它的各种操作API都是最新的,但是性能不高
- ODBC的基本原理
- 通过一个数据源名称 —> 数据库
- 为数据库起了一个别名 —> 程序通过别名访问数据库
- 即:程序只认别名不认具体的数据库
- 常用接口:
- 使用java.sql包
- 常用接口:–DriverManager –Connection –Statement –PreparedStatement –ResultSet
- **利用JDBC开发WEB数据库应用框架
- 装入JDBC驱动程序
- 创建与数据库的连接
- 创建语句对象
- 利用语句对象执行SQL语句得到结果
- 处理结果
- JDBC应用结束,关闭各项操作
阅读全文…
alex Java Java, jdbc, jsp, odbc
什么是JavaBean?JavaBean就是一个Java类,即意味着JAVA的一切特性都可以使用,此JavaBean没有图形显示代码,只是完成基本的业务逻辑。
- JavaBean可以使用Java的封装、继承、多态
- 使用JavaBean封许多可重复调用的代码–>JavaBean的开发过程是通过项目的不断积累经验的。
- 使用JavaBean可以达到显示与业务的分离:显示用JSP,业务用JavaBean
- JAVA开发人员专注于具体业务的开发,而JSP开发人员专注于效果的开发
将JavaBean编译好的*.class文件拷贝到WEB-INF/classes文件夹下,若无此文件夹可以自行建立
编写JavaBean必须需要满足的几点要求:
- 所有的JavaBean必须放在同一个包中
- JavaBean必须声明成public class类型 –> 文件名称与类名一致
- 所有属性必须封装
- 设置和取得属性可以通过setter、getter
- 使用JSP标签去调用JavaBean必须有一个无参构造方法
JAVA命名规范:
- 包命名:全部字母小写
- 类命名:单词的首字母大写,eg.SimpleBean
- 属性名称:第一个单词的首字母小写,之后每单词的首字母大写,eg.studentName
- 方法命名:与属性命名相同,eg.public class sayHello(){}
- 常量命名:全部单词大写,eg.final String DBDRIVER = "XXXX";
对JAVA程序进行打包编译:javac -d . 文件名
JavaBean开发完成之后在JSP中调用过程:
- 使用<%@page import=""%> 使用导入指令
- 实际上WEB-INF/classes是一个classpath路径,所有的class文件,只要放在此目录下,都可以被访问到
- 使用JSP的标签指令调用
- <jsp:useBean
id = "sb" //表示实例化对象的名称
scope="page" //表示使用范围
class="net.hialex.bean.SimpleBean"/> //对象所属包.类名称路径
- Tomcat服务器在默认情况下是不能读取修改后的JavaBean如果要读取有以下两种方式:
- 重新启动服务器
- 配置%TOMCAT_HOME%/conf/web.xml参数reloadable="true"
- 使用reloadable参数的时机选择:
- 如果使用这个参数,则表示服务器要始终监视着是否类有改动–这样做影响服务器的性能
- 在运行时,这个参数必须去掉
- 在开发时,为了开发方便,可加入此参数
使用JavaBean的好处:
- 必须结合用户参数提交才能够发现使用JavaBean的好处
- 使用以下的代码可以替代一切的setter方法调用
- <jsp:setProperty name = "sb" property="*"/>
- name:已经声明过的JavaBean对象的id
- property:表示要设置的属性,如果为"*"则表示自动匹配
alex Java bean, Java, javabean, jsp, 命名, 标签, 规范
最新评论