咨询热线:020-82315523 18988993510 18988993505

JSP环境中安装MySQL管理jspmyadmin过程遇到的问题及解决方法 .

在使用MySQL数据库时,我用的是jspmyadmin的图形管理界面来管理该数据库,我的
步骤是:
第一步:下载jspmyadmin,网址:http://sourceforge.net/projects/jspmyadmin/
页面

第二步:将下载的jspmyadmin压缩文件(jspmyadmin0.6.zip)解压后,将该文件夹全部复制到网站服务器Tomcat的Webapps目录下,因此它的路径为D:/Tomcat 6.0/webapps/jspmyadmin

第三步:经过上面的设置后,如果在IE浏览器的地址栏中输入http://localhost:8080/jspmyadmin/,则会发现jspmyadmin管理接口无法正常显示,这是因为还没有修改jspmyadmin数据库状态设置文件config.inc.jsp,由于Mysql数据库默认的连接端口是3306,因此打开jspmyadmin文件夹下的config.inc.jsp文件后修改第13行的程序代码port=3306。

第四步:但此时重新在地址栏中输入http://localhost:8080/jspmyadmin/,又会出现
http status 500的错误,页面出现的代码为:
HTTP Status 500 -

-----------------------------------------------------

type Exception report

message

description The server encountered an internal error () that prevented it
from fulfilling this request.

exception

org.apache.jasper.JasperException: Unable to compile class for JSP:

An error occurred at line: 43 in the jsp file: /lib.inc.jsp
Enumeration cannot be resolved
40: pageContext.setAttribute(PROPERTIES_REQUEST_KEY,myproperties,
pageContext.SESSION_SCOPE);
41: }
42: Hashtable all = new Hashtable();
43: Enumeration enum = myproperties.propertyNames();
44: while (enum.hasMoreElements()) {
45: String key= (String)enum.nextElement();
46: String value= myproperties.getProperty( key );


An error occurred at line: 44 in the jsp file: /lib.inc.jsp
Syntax error on token "enum", invalid expression_r_r
41: }
42: Hashtable all = new Hashtable();
43: Enumeration enum = myproperties.propertyNames();
44: while (enum.hasMoreElements()) {
45: String key= (String)enum.nextElement();
46: String value= myproperties.getProperty( key );
47: all.put( key, value );


An error occurred at line: 45 in the jsp file: /lib.inc.jsp
Syntax error on token "enum", delete this token
42: Hashtable all = new Hashtable();
43: Enumeration enum = myproperties.propertyNames();
44: while (enum.hasMoreElements()) {
45: String key= (String)enum.nextElement();
46: String value= myproperties.getProperty( key );
47: all.put( key, value );
48: }


Stacktrace:
org.apache.jasper.compiler.DefaultErrorHandler.javacError
(DefaultErrorHandler.java:93)
org.apache.jasper.compiler.ErrorDispatcher.javacError
(ErrorDispatcher.java:330)
org.apache.jasper.compiler.JDTCompiler.generateClass(JDTCompiler.java:435)
org.apache.jasper.compiler.Compiler.compile(Compiler.java:298)
org.apache.jasper.compiler.Compiler.compile(Compiler.java:277)
org.apache.jasper.compiler.Compiler.compile(Compiler.java:265)
org.apache.jasper.JspCompilationContext.compile
(JspCompilationContext.java:564)
org.apache.jasper.servlet.JspServletWrapper.service
(JspServletWrapper.java:302)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:329)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:265)
javax.servlet.http.HttpServlet.service(HttpServlet.java:803)

note The full stack trace of the root cause is available in the Apache
Tomcat/6.0.20 logs.
该问题的解决方法为:修改第lib.inc.jsp文件的43行:Enumeration enum = myproperties.propertyNames(); 中的enum改为enum_new,下面几行中也有几处enum,一并修改,注意不要改错了,只修改enum变量为enum_new;这主要是因为新版本的Jspmyadmin中enum已经变成关键字了,所以enum不能作为变量名,这里就是发生了变量名与关键字的冲突。

第五步:就在我们觉得快大功告成的时候,又出现了新的问题。同样我们在地址栏中输入访问的地址,打开的网页显示的代码如下:
Oops! an exception occurred.
The exception was: java.sql.SQLException: Invalid authorization specification: Access denied for user 'root'@'localhost' (using password: NO)
The exception class was : class java.sql.SQLException
我原来的解决方法是打开jspmyadmin文件夹下的config.inc.jsp文件,修改password=“我实际用的数据库的密码”,但是又出现新的问题:
Oops! an exception occurred.
The exception was: java.sql.SQLException: Communication failure during handshake. Is there a server running on localhost:3306?
The exception class was : class java.sql.SQLException
所以我个人认为jspmyadmin管理Mysql数据库,该数据库的密码必须改为空,以下为修改数据库密码的代码:
mysql->use mysql;
mysql->update mysql.use set password = password(‘’) where user=’root’;
mysql->flush privileges;
mysql->quit

以上代码都是命令,打开MySQL Command Line Client ,输入密码进入MysQL,就可以按上面的输入命令
这下在输入访问地址,成功的进入jspmyadmin 管理界面。

补充:修改jspmyadmin中文编码
打开Tomcat服务器的jspmyadmin 文件夹,找到其中的lib.inc.jsp文件并打开该文件.在第17行加上程序代码如下:contentType=”text/html;charset = gb2312”,也就是将第17行改成如下的程序代码:
<%@ page contentType=”text/html;charset=gb2312” language=”java” import=”java.text.*,java.sql.*,java.util.*,java.io.*,java.net.*,com.jspmyadmin,*” errorPage=”error..jsp” %>
在第21行按下Enter键空出一行,并加上如下程序代码:
Request,setCharacterEncoding(“gb2312”);
这样在jspmyadmin管理界面中输入中文字,中文字可以正常显示了。
 

 

另外:
使用了tomcat6.0,然后JspMyAdmin是从SourceGet上下载的
由于是不需要安装的版本,我就直接放到WebApps下面了,问题来了
能看到登陆画面,就是登陆了之后,进去的页面是混乱的。
后来找到原因了:
login.jsp
里面有一段:
String User="root";
String Pass=""; //****这一行是密码,要改了
String Host="localhost";
String Port="3306";
改动之后,立马就登陆成功了!!

 

如果出现500错误如:

org.apache.jasper.JasperException: Unable to compile class for JSP: 

An error occurred at line: 43 in the jsp file: /lib.inc.jsp
Enumeration cannot be resolved
40: pageContext.setAttribute(PROPERTIES_REQUEST_KEY,myproperties, pageContext.SESSION_SCOPE);
41: }
42: Hashtable all = new Hashtable();
43: Enumeration enum = myproperties.propertyNames();
44: while (enum.hasMoreElements()) {
45: String key= (String)enum.nextElement();
46: String value= myproperties.getProperty( key );


An error occurred at line: 43 in the jsp file: /lib.inc.jsp
Syntax error on token "enum", delete this token
40: pageContext.setAttribute(PROPERTIES_REQUEST_KEY,myproperties, pageContext.SESSION_SCOPE);
41: }
42: Hashtable all = new Hashtable();
43: Enumeration enum = myproperties.propertyNames();
44: while (enum.hasMoreElements()) {
45: String key= (String)enum.nextElement();
46: String value= myproperties.getProperty( key );


An error occurred at line: 44 in the jsp file: /lib.inc.jsp
Syntax error on token "enum", invalid Expression
41: }
42: Hashtable all = new Hashtable();
43: Enumeration enum = myproperties.propertyNames();
44: while (enum.hasMoreElements()) {
45: String key= (String)enum.nextElement();
46: String value= myproperties.getProperty( key );
47: all.put( key, value );


An error occurred at line: 45 in the jsp file: /lib.inc.jsp
Syntax error on token "enum", delete this token
42: Hashtable all = new Hashtable();
43: Enumeration enum = myproperties.propertyNames();
44: while (enum.hasMoreElements()) {
45: String key= (String)enum.nextElement();
46: String value= myproperties.getProperty( key );
47: all.put( key, value );
48: }


Stacktrace:
org.apache.jasper.compiler.DefaultErrorHandler.javacError(DefaultErrorHandler.java:92)
org.apache.jasper.compiler.ErrorDispatcher.javacError(ErrorDispatcher.java:330)
org.apache.jasper.compiler.JDTCompiler.generateClass(JDTCompiler.java:443)
org.apache.jasper.compiler.Compiler.compile(Compiler.java:362)
org.apache.jasper.compiler.Compiler.compile(Compiler.java:340)
org.apache.jasper.compiler.Compiler.compile(Compiler.java:327)
org.apache.jasper.JspCompilationContext.compile(JspCompilationContext.java:594)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:314)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:320)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:265)
javax.servlet.http.HttpServlet.service(HttpServlet.java:722)

在你的jsp页面上部<%@page language="java" contentType="text/html; charset=GB2312" pageEncoding="GB2312"%>之后加上下面这句<%@page import="java.util.Enumeration"%>就好了,使用类之前,要先引入那个类,这句话就是引入Enumeration这个类的

导入java.util.*;这个包,才有Enumerationenum这个变量是关键字,不能用他

在你的jsp中,
没有import需要的类:
<% @page import="java.util" %>

原来的JspMyadmin估计是1.4的基础上写的,到1.6时enum变成了关键字,所以我就参考Google搜索结果尝试自己修改了一下lib.inc.jsp,结果居然成功了。现将解决办法共享给大家:
1、修改第43行:Enumeration enum = myproperties.propertyNames(); 中的enum改为enum_new,下面几行中也有几处enum,一并修改,注意不要改错了,只修改enum变量为enum_new;
2、上述一处修改完毕后,再刷新浏览器,又报318行错误,因此修改318行,enumeration en = index.keys;为Enumeration,估计这里是作者把字母大小写给弄错了。
至此,整个文件修改完毕,刷新浏览器后,就出现了我们熟悉的PhpMyadmin界面了,当然,我们用的JspMyadmin是从PhpMyadmin修改过来的。

迅恒运营的IDC数据中心机房介绍
机房名称 机房介绍 是否推荐
广州较场西路机房 中国电信5星级机房,华南骨干出口,广州市中心机房,交通便利,总带宽200G,为华南骨干出口。
广州人民中路机房 中国电信3星级机房,超高速的20Gx2主备双线路带宽直接接入ChinaNET骨干层。
广州天河科技园机房 天河软件园建中路4号,中国互联网应急中心机房,国家政府机关直属。多线接入骨干BGP线路。
电子商务部广州机房 天河软件建业路上(科韵路)的国际电子商务中心大厦甲级写字楼内,机房环境一流。多线接入骨干BGP线路。
广州电信加速器机房 位于广州市萝岗区开源大道1号企业加速器B1栋一楼,按照国际T3+及国标B+级标准建造,机房环境一流。多线接入骨干网。
广州移动旗锐机房 广州科学城南翔二路1号旗锐数字科技园区内,属于第三方私立机房,现由移动运营,从粤西汇聚节点直连CMNET骨干网。
广州移动南方基地机房 中国移动广州南方基地机房位于广州市天河软件园高塘大道333号,用于移动骨干网线路,是移动服务器托管优质机房。
东莞电信道滘机房 中国电信4星级机房,总带宽320G,可提供电信和多线BGP线路,华南骨干机房,稳定高速,性价比高。
东莞电信东城机房 中国电信4星级机房,总带宽320G,性价比高,可提供电信和多线BGP线路和200G集群硬件防火墙VIP防护。
东莞电信樟木头机房 中国电信4星级机房,总带宽320G,可提供电信和多线BGP线路和100G集群硬件防火墙企业级防护。
深圳互联港湾机房 深圳南山高新区中区软件大厦四楼,电信3星级机房,20G带宽接入骨干网络。
深圳南山科兴机房 位于深圳市南山区科技园科苑路15号科兴科学园,3星级机房,可提供双线接入等业务。
深圳百旺信机房 深圳市南山区西丽松白公路百旺信工业区A区(一区)一栋属于第三方机房,可提供双线接入等业务。
佛山电信信息大厦机房 佛山市汾江南路35号电信佛山分公司信息大厦8-9层,是中国电信3星级机房,可提供双线接入等业务。
中山电信火炬机房 机房位于中山市火炬区康乐大道47号电信3楼,是中国电信3星级机房,可提供双线接入等业务。
江苏徐州电信机房 机房位于江苏徐州市新城区镜泊东路4号,徐州市档案馆东侧,是中国电信3星级机房,可提供双线接入等业务。
江苏常州电信机房 机房位于江苏省常州市清凉路108号常州信息港,是中国电信4星级机房,可提供双线接入等业务。
香港TKO机房 机房靠近香港交易所的数据中心位置和香港商业中心,拥有PCCW、GTT、Cogent、Telia、TATA、CT、CN2、CU线路。
香港将军澳机房 机房在香港新界將軍澳工業邨駿昌街22號,与阿里云香港机房同属一栋楼,拥有多种线路接入。
香港新世界机房 香港新世界机房的海底电缆系统遍布全球,能直接连接多个国家,免备案,服务器租用、云服务器等业务。
香港NTT机房 香港NTT电讯机房,是一座专用数据中心,在香港大埔,免备案,提供服务器租用、VPS云服务器等业务。
美国洛杉矶机房 位于美国洛杉矶,直连全球,是全球带宽最集中的地方,是外贸企业首选,该机房只提供服务器租用业务。
美国加州DCS机房 位于美国加州,直连全球,是美国的华人机房,是外贸企业首选,该机房只提供服务器租用业务。
美国圣何塞机房 位于美国圣何塞,紧邻科技中心-硅谷,直连全球,是外贸企业首选,该机房只提供服务器租用业务。
韩国首尔KT机房 韩国首尔的江南区道谷洞数据中心,光纤直连电信(CN2)、移动、PCCW、NTT等网络核心骨干。
台湾中华电信机房 台湾中华电信机房位于台湾台北市114内湖区瑞光路68号3楼,是台湾对外最重要的电信枢纽之一。
菲律宾PLDT机房 菲律宾PLDT机房拥有PCCW、TATA、CT、CN2等线路接入,优化线路到中国大陆速度快,延迟低,网络稳定。
迅恒十多年IT企业和IDC运维经验为您提供优质服务
迅恒专注网站建设10多年,几十人技术团队,品质卓越,服务有保障!
  • 云虚拟主机

    ¥99元/年起 网站空间 原价:199元

  • 独立物理服务器

    ¥488/月起 物理机 原价:699元

  • 网站建设

    ¥580企业建站 原价:1999元起

    迅恒建站·ABOUT US

    迅恒专注于企业建站,海量精美网站风格模板供您选择!

广州网站设计公司哪家好

    建站流程·PROCEDURE

    网络营销推广的第一步就是做一个属于自己的网站

  • 沟通联系

    提出需求,咨询报价
  • 达成协议

    交流达成详细建站协议
  • 支付费用

    支付建站相关费用
  • 建站开发

    根据客户需求,制作网站
  • 验收

    客户验收网站
  • 提交上线

    验收合格,解析域名上线
  • 售后服务

    一对一的售后服务客服
    • 我们的优势·OUR STRENGTHS

      做网站,为什么要选迅恒建站?

  • 技术团队

    专业的设计团队、技术团队,为客户提供专业的技术服务支持

  • 源码交付

    客户查验合格,提供源码交付/FTP信息。网站商业授权,避免产权纠纷

  • 四合一建站多终端展示

    网站能够在CP+平板+手机+小程序 完美响应展示。

  • 无隐形收费

    所有收费项公开透明,正规签订合同,合同清楚明确

  • 高端设计

    提供网站个性化定制设计,拒绝千篇一律

  • 安全稳定

    我司与华为云/腾讯云长期合作,采用安全稳定服务器,保障网站安全稳定运行

  • 迅恒累计为上万网站稳定运行 100000000
    机房接入电信带宽400G、联通带宽200G、移动带宽100G,直连核心骨干网络;
    所有重要网络节点和核心设备均采用华为电信级交换设备,网络总体交换能力高达684G,网络联通率达到99.99%,
    并且多点冗余备份,提高网络性能,避免单点故障。
  • 快速导航
  • 广州迅恒信息科技有限公司:
  • 增值电信业务经营许可证和ICP备案 粤B2-20061054
  • 公司业务咨询电话:
  • 020-82315523
  • 公司企业QQ/商务QQ:
  • 938040335 16764407 923109991 20300996
  • 销售经理:18988993510 13533213185
  • 备案咨询和售后服务电话:18988993505
  • 专注广州服务器托管
    请加销售经理微信
    Copyright 2005-2020 迅恒 版权所有   公司地址:广州市天河区中山大道中路77号  广州机房:较长西路21号广州电信超级信息港 香港机房:香港新界葵涌葵丰街钟意恒胜中心  粤公网安备44010602002183