java - 使用 Java 将 Flex 与 Blazeds 集成的问题

标签 java apache-flex postgresql flex4 blazeds

我叫 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 代码中。如果有人有想法请帮助我。

非常感谢, 拉胡尔

最佳答案

  1. 您应该在服务器代码中使用日志记录(例如 log4j、slf4j)来记录您的异常。
  2. 您不应返回作为 insertData() 结果的消息,而应返回成功代码或简单地抛出异常。两者都可以在客户端处理,这样可以更轻松地显示本地化消息。
  3. 使用连接池并在完成工作后立即关闭连接。
  4. 只需定义一个本地Statement 变量,最后调用close()
  5. 熟悉debugging web applications in Tomcat
  6. 使用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/

相关文章:

java - Netbeans 禁用水平滚动

java - Zend Lucene 是否需要 Java Lucene?

java - 通过 BlazeDS 从 Java 到 Flex 的自定义编码

apache-flex - Flash/Flex 中 Speex 编解码器的 API

postgresql - plpgsql For循环中的Select语句创建多个CSV文件

java - 搜索网格中每个图 block 的相邻图 block 的有效方法?

java - Hibernate 与引用列的一对一映射(XML 映射)

apache-flex - Flex 4 文件引用选定的图像文件尺寸(宽度和高度)

python - Django 中的日期时间问题

java - Postgres JDBC 驱动程序 `org.postgresql.ds.PGSimpleDataSource` 是线程安全的吗?