Проблема интеграции Flex с Blazeds с использованием Java - PullRequest
1 голос
/ 20 мая 2011

Меня зовут Рахул. Я новичок в сгибании. Я пытаюсь интегрировать Flex с Blazeds с помощью Java. Я написал некоторый код согласно моим знаниям. Но это не подключение к базе данных. Я вставляю свой код здесь. Пожалуйста, посмотрите на это и дайте мне знать, если я сделал там какие-либо ошибки:

Мой код 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:

FeedbackVO.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;
}   
}

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. есть идея, пожалуйста, помогите мне.

Большое спасибо, Рахул

Ответы [ 2 ]

1 голос
/ 20 мая 2011
  1. Вы должны использовать логирование (например, log4j, slf4j) в коде своего сервера для регистрации ваших исключений.
  2. Вместо того, чтобы возвращать сообщение в результате insertData(), вы должны вернуть код успеха или просто выбросить исключение. Оба могут быть обработаны на стороне клиента, где легче показать локализованное сообщение.
  3. Используйте пул подключений и закройте подключение сразу после завершения работы.
  4. Просто определите локальную Statement переменную и, наконец, вызовите close ()
  5. Ознакомьтесь с отладкой веб-приложений в Tomcat
  6. Используйте executeUpdate () , и ваша ошибка должна исчезнуть. execute () возвращает false, если результатом является счетчик обновлений, и вы выполняете оператор INSERT, поэтому он сделает это.

Это было бы мое предложение:

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;      
    }
}
0 голосов
/ 20 мая 2011

Что-то пошло не так с INSERT.Трудно сказать, что (основной синтаксис в порядке), но простое объединение строк делает его уязвимым для специальных символов, таких как кавычки в значениях, передаваемых в запрос (и атаки с использованием SQL-инъекций).Гораздо лучше использовать Подготовленные операторы

Также напечатанные трассировки стека исключений могут содержать полезную информацию для решения проблемы.

...