我叫 Rahul。我是 flex 的新手。我正在尝试使用 java 将 flex 与 blazeds 集成。我已经根据我的知识编写了一些代码。但它没有连接到数据库。我在这里粘贴我的代码。请查看此内容,如果我在那里做错了请告诉我:
我的 Flex 代码:
<fx:Script>
<![CDATA[
import com.hello.vo.FeedbackVO;
import mx.controls.Alert;
import mx.rpc.events.FaultEvent;
import mx.rpc.events.ResultEvent;
import mx.utils.ObjectUtil;
public function insertData():void
{
var feedbackvo:FeedbackVO = new FeedbackVO();
feedbackvo.name = input_name.text;
feedbackvo.number = input_number.text;
feedbackvo.email = input_email.text;
feedbackvo.feedback = input_feedback.text;
ro.insertData(feedbackvo);
}
public function onResult(event:ResultEvent):void
{
Alert.show(ObjectUtil.toString(event.result));
}
public function onFault(event:FaultEvent):void
{
Alert.show(ObjectUtil.toString(event.fault));
}
]]>
</fx:Script>
<fx:Declarations>
<!-- Place non-visual elements (e.g., services, value objects) here -->
<s:RemoteObject id="ro"
destination="feedback"
source="com.hello.Feedback"
endpoint="http://localhost:8082/Feedback/messagebroker/amf">
<s:method name="insertData"
result="onResult(event)"
fault="onFault(event)"/>
</s:RemoteObject>
</fx:Declarations>
<s:BorderContainer x="0"
y="0"
width="100%"
height="100%">
<s:Panel width="364"
height="333" x="206" y="83">
<mx:Form x="0"
y="0"
width="100%"
height="100%">
<mx:FormItem label="Name:">
<s:TextInput id="input_name" width="249"/>
</mx:FormItem>
<mx:FormItem label="Number:">
<s:TextInput id="input_number" width="249"/>
</mx:FormItem>
<mx:FormItem label="Email:">
<s:TextInput id="input_email" width="248"/>
</mx:FormItem>
<mx:FormItem label="Feedback:">
<s:TextInput id="input_feedback" width="248" height="143"/>
</mx:FormItem>
<mx:FormItem>
<s:Button id="insert_btn"
label="Insert Data"
click="insertData();"/>
</mx:FormItem>
</mx:Form>
</s:Panel>
</s:BorderContainer>
我的 Java 代码:
反馈VO.java:
package com.hello.vo;
public class FeedbackVO
{
private String name;
private String number;
private String email;
private String feedback;
public String getName()
{
return name;
}
public void setName(String name)
{
this.name = name;
}
public String getNumber()
{
return number;
}
public void setNumber(String number)
{
this.number = number;
}
public String getEmail()
{
return email;
}
public void setEmail(String email)
{
this.email = email;
}
public String getFeedback()
{
return feedback;
}
public void setFeedback(String feedback)
{
this.feedback = feedback;
}
}
反馈.java:
package com.hello;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import com.hello.vo.FeedbackVO;
public class Feedback
{
Connection connection;
Statement stmt;
ResultSet rs;
public Feedback()
{
String host = "localhost";
String port = "5432";
String dbName = "test";
Connection connection = null;
try
{
connection = DriverManager.getConnection(
"jdbc:postgresql://" + host + ":" + port + "/" + dbName,"postgres", "admin");
System.out.println("Database is connected");
stmt = connection.createStatement();
}
catch (Exception e)
{
e.printStackTrace();
}
}
public String insertData(FeedbackVO feedbackvo)
{
try
{
stmt = connection.createStatement();
String sql = "INSERT into feedback(name,number,email,feedback) VALUES ('" + feedbackvo.getName() + "','" + feedbackvo.getNumber() + "','" + feedbackvo.getEmail() + "','" + feedbackvo.getFeedback() +"')";
if(stmt.execute(sql))
{
return "Thanks For your Valuable Feedback";
}
}
catch (Exception e)
{
e.printStackTrace();
}
return "Sorry Your feedback is not entered";
}
}
如果我尝试执行 Feedback.mxml 然后我得到“抱歉您的反馈未输入”作为输出。我不知道问题出在哪里。我认为 flex 已成功连接但问题出在 java 代码中。如果有人有想法请帮助我。
非常感谢, 拉胡尔
最佳答案
- 您应该在服务器代码中使用日志记录(例如 log4j、slf4j)来记录您的异常。
- 您不应返回作为
insertData()
结果的消息,而应返回成功代码或简单地抛出异常。两者都可以在客户端处理,这样可以更轻松地显示本地化消息。 - 使用连接池并在完成工作后立即关闭连接。
- 只需定义一个本地
Statement
变量,最后调用close() - 熟悉debugging web applications in Tomcat
- 使用executeUpdate()你的错误应该消失了。 execute()如果结果是更新计数并且您正在执行
INSERT
语句,那么它会这样做,则返回false
。
这是我的建议:
private Connection getConnection() throws SQLException
{
// get a connection from the connection pool
}
public int insertFeedback(FeedbackVO feedbackvo) throws SQLException
{
try
{
Connection con = getConnection();
try
{
String sql = "INSERT INTO feedback(name,number,email,feedback) " +
"VALUES (?, ?, ?, ?)";
PreparedStatement stmt = connection.prepareStatement();
try
{
stmt.setString(1, feedbackvo.getName());
stmt.setString(2, feedbackvo.getNumber());
stmt.setString(3, feedbackvo.getEmail());
stmt.setString(4, feedbackvo.getFeedback());
return stmt.executeUpdate(sql);
}
finally
{
stmt.close();
}
}
finally
{
con.close();
}
}
catch (SQLException e)
{
log.error(e);
throw e;
}
}
关于java - 使用 Java 将 Flex 与 Blazeds 集成的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6067554/