如何调用Hibernate和struts 2的pojo类setter方法【会话文件上传应用】中的另一个方法

发布于 2025-01-08 07:46:44 字数 5200 浏览 0 评论 0原文

嗨,朋友们,我正在开发一个使用 hibernate 和 struts2 的 Web 应用程序。我正在创建相册,我在不使用休眠的情况下成功完成了该操作,但是使用休眠时,在插入数据库时​​出现问题。该模块会像这样工作,一旦文件上传,它将插入文件名、内容类型、id,并且它应该插入图像文件(字节[])内容,但它在表值中显示空。我的代码是这样的...

@Entity
@Table(name="PHOTOALBUM")
public class User implements Serializable  {
@Id
@GeneratedValue
@Column(name="PHOTO_ID")
    private Long id;

@Column(name="IMAGE")
private byte[] Image;


@Column(name="CONTENT_TYPE")
    private String userImageContentType;

@Column(name="PHOTO_NAME")
    private String userImageFileName;

            public Long getId() {
    return id;
}
public void setId(Long id) {
    this.id = id;
}

            public String getUserImageFileName() {
        return userImageFileName;
    }

    public void setUserImageFileName(String userImageFileName) {
        this.userImageFileName = userImageFileName;
    }

            public String getUserImageContentType() {
        return userImageContentType;
    }

    public void setUserImageContentType(String userImageContentType) {
        this.userImageContentType = userImageContentType;
    }

public byte[] getImage() {
        return Image;
    }

    public void setImage(byte[] Image) {
        Image=Change(this.getUserImage());
        this.Image = Image;
    }

    @Transient
    private File userImage;

    public File getUserImage() {
        return userImage;
    }

    public void setUserImage(File userImage) {
        this.userImage = userImage;
    }

    public byte[] Change(File userImage)
    {
       // userImage=this.getUserImage();
       // String name=userImage.getName();
       // long len=userImage.length();

        byte[] bFile = new byte[(int) userImage.length()];
        try {

        FileInputStream fileInputStream = new FileInputStream(userImage);
    fileInputStream.read(bFile);
    fileInputStream.close();
        }
        catch(Exception e)
        {
            e.printStackTrace();
        }
       // System.out.println("The Name Of File In Pojo Class Is:="+ name);
        //System.out.println("The Length Of File In Pojo Class Is:="+ len);
        //System.out.println("The Content Of File In Pojo Class Is:="+ bFile);
        return bFile;
    }

}

我正在保存这样的值,

 public class UserDAOImpl implements UserDAO {

@SessionTarget
Session session;

@TransactionTarget
Transaction transaction;

/**
 * Used to save or update a user.
 */
@Override
public void saveOrUpdateUser(User user) {
    try {
        session.saveOrUpdate(user);
    } catch (Exception e) {
        transaction.rollback();
        e.printStackTrace();
    }
}

/**
 * Used to delete a user.
 */
@Override
public void deleteUser(Long userId) {
    try {
        User user = (User) session.get(User.class, userId);
        session.delete(user);
    } catch (Exception e) {
        transaction.rollback();
        e.printStackTrace();
    } 
}

/**
 * Used to list all the users.
 */
@SuppressWarnings("unchecked")
@Override
public List<User> listUser() {
    List<User> courses = null;
    try {
        courses = session.createQuery("from User").list();
    } catch (Exception e) {
        e.printStackTrace();
    }
    return courses;
}

/**
 * Used to list a single user by Id.
 */
@Override
public User listUserById(Long userId) {
    User user = null;
    try {
        user = (User) session.get(User.class, userId);
    } catch (Exception e) {
        e.printStackTrace();
    }
    return user;
}

}

struts动作映射是这样的...

 \<package name="default" extends="hibernate-default">
<action name="saveOrUpdateUser"method="saveOrUpdate"class="com.srikanth.web.UserAction">
        <result name="success" type="redirect">listUser</result>
    </action>
    <action name="listUser" method="list" class="com.srikanth.web.UserAction">
        <result name="success">/register.jsp</result>
    </action>
    <action name="editUser" method="edit" class="com.srikanth.web.UserAction">
        <result name="success">/register.jsp</result>
    </action>
    <action name="deleteUser" method="delete" class="com.srikanth.web.UserAction">
        <result name="success" type="redirect">listUser</result>
    </action>
</package>

我的jsp是这样的

 \<s:form action="saveOrUpdateUser">
<s:push value="user">
    <s:hidden name="id" />
    <s:file name="userImage" label="User Image" />
            <s:submit />
</s:push>
 </s:form>
 <s:iterator value="userList" status="userStatus">
        <s:property value="id" />
            <s:property value="userImageFileName" />
            <s:property value="userImageContentType" />
            <img src='<s:property value="userImage" />' alt"" />
            <s:url id="deleteURL" action="deleteUser">
                <s:param name="id" value="%{id}"></s:param>
            </s:url> <s:a href="%{deleteURL}">Delete</s:a>
    </s:iterator>

我试图调用更改方法,以便它将文件转换为字节[]并将其存储在字节中[] 使用 setter 的图像变量但它不起作用...... 所以请帮我解决这个问题...... 提前致谢

Hi Friends i am developing an web application which uses hibernate and struts2. i am creating photo album i successfully done that with out using hibernate but, with hibernate it is having problem while inserting to the database. the module works like this as soon as the file uploaded it will insert the FileName, Contenttype,id and it suppose to insert the Image File(byte[]) Content also but it is showing Null in table value.. my code goes like this...

@Entity
@Table(name="PHOTOALBUM")
public class User implements Serializable  {
@Id
@GeneratedValue
@Column(name="PHOTO_ID")
    private Long id;

@Column(name="IMAGE")
private byte[] Image;


@Column(name="CONTENT_TYPE")
    private String userImageContentType;

@Column(name="PHOTO_NAME")
    private String userImageFileName;

            public Long getId() {
    return id;
}
public void setId(Long id) {
    this.id = id;
}

            public String getUserImageFileName() {
        return userImageFileName;
    }

    public void setUserImageFileName(String userImageFileName) {
        this.userImageFileName = userImageFileName;
    }

            public String getUserImageContentType() {
        return userImageContentType;
    }

    public void setUserImageContentType(String userImageContentType) {
        this.userImageContentType = userImageContentType;
    }

public byte[] getImage() {
        return Image;
    }

    public void setImage(byte[] Image) {
        Image=Change(this.getUserImage());
        this.Image = Image;
    }

    @Transient
    private File userImage;

    public File getUserImage() {
        return userImage;
    }

    public void setUserImage(File userImage) {
        this.userImage = userImage;
    }

    public byte[] Change(File userImage)
    {
       // userImage=this.getUserImage();
       // String name=userImage.getName();
       // long len=userImage.length();

        byte[] bFile = new byte[(int) userImage.length()];
        try {

        FileInputStream fileInputStream = new FileInputStream(userImage);
    fileInputStream.read(bFile);
    fileInputStream.close();
        }
        catch(Exception e)
        {
            e.printStackTrace();
        }
       // System.out.println("The Name Of File In Pojo Class Is:="+ name);
        //System.out.println("The Length Of File In Pojo Class Is:="+ len);
        //System.out.println("The Content Of File In Pojo Class Is:="+ bFile);
        return bFile;
    }

}

and i am saving the values like this

 public class UserDAOImpl implements UserDAO {

@SessionTarget
Session session;

@TransactionTarget
Transaction transaction;

/**
 * Used to save or update a user.
 */
@Override
public void saveOrUpdateUser(User user) {
    try {
        session.saveOrUpdate(user);
    } catch (Exception e) {
        transaction.rollback();
        e.printStackTrace();
    }
}

/**
 * Used to delete a user.
 */
@Override
public void deleteUser(Long userId) {
    try {
        User user = (User) session.get(User.class, userId);
        session.delete(user);
    } catch (Exception e) {
        transaction.rollback();
        e.printStackTrace();
    } 
}

/**
 * Used to list all the users.
 */
@SuppressWarnings("unchecked")
@Override
public List<User> listUser() {
    List<User> courses = null;
    try {
        courses = session.createQuery("from User").list();
    } catch (Exception e) {
        e.printStackTrace();
    }
    return courses;
}

/**
 * Used to list a single user by Id.
 */
@Override
public User listUserById(Long userId) {
    User user = null;
    try {
        user = (User) session.get(User.class, userId);
    } catch (Exception e) {
        e.printStackTrace();
    }
    return user;
}

}

the struts action mapping goes like this...

 \<package name="default" extends="hibernate-default">
<action name="saveOrUpdateUser"method="saveOrUpdate"class="com.srikanth.web.UserAction">
        <result name="success" type="redirect">listUser</result>
    </action>
    <action name="listUser" method="list" class="com.srikanth.web.UserAction">
        <result name="success">/register.jsp</result>
    </action>
    <action name="editUser" method="edit" class="com.srikanth.web.UserAction">
        <result name="success">/register.jsp</result>
    </action>
    <action name="deleteUser" method="delete" class="com.srikanth.web.UserAction">
        <result name="success" type="redirect">listUser</result>
    </action>
</package>

and my jsp goes like this

 \<s:form action="saveOrUpdateUser">
<s:push value="user">
    <s:hidden name="id" />
    <s:file name="userImage" label="User Image" />
            <s:submit />
</s:push>
 </s:form>
 <s:iterator value="userList" status="userStatus">
        <s:property value="id" />
            <s:property value="userImageFileName" />
            <s:property value="userImageContentType" />
            <img src='<s:property value="userImage" />' alt"" />
            <s:url id="deleteURL" action="deleteUser">
                <s:param name="id" value="%{id}"></s:param>
            </s:url> <s:a href="%{deleteURL}">Delete</s:a>
    </s:iterator>

I am trying to call the Change Method so that it convert the file to byte[] and stored it in byte[] Image variable using setter but it is not working....
So please help me with this one .....
thanks in advance

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

归途 2025-01-15 07:46:44

根据我对问题的理解,问题只是将文件插入表中。复制&将 Change() 方法粘贴到 com.srikanth.web.UserAction 类中,因为您对每个数据库事务都使用此操作。在数据库中插入/更新之前使用 Change() 方法。

例如:

public class UserAction extends ActionSupport{
   //variable to get file from jsp
   private File uploadedImage;
    .....
   //setters & getters for uploadedImage


@Override
public String gsexecute() throws Exception {

   User user = new User();

   //set image value as byteArray
   user.setImage(Change(uploadedImage));

   //insert or update DB here

    return SUCCESS;
}

 public byte[] Change(File userImage)
   {
   // userImage=this.getUserImage();
   // String name=userImage.getName();
   // long len=userImage.length();

    byte[] bFile = new byte[(int) userImage.length()];
    try {

    FileInputStream fileInputStream = new FileInputStream(userImage);
fileInputStream.read(bFile);
fileInputStream.close();
    }
    catch(Exception e)
    {
        e.printStackTrace();
    }
   // System.out.println("The Name Of File In Pojo Class Is:="+ name);
    //System.out.println("The Length Of File In Pojo Class Is:="+ len);
    //System.out.println("The Content Of File In Pojo Class Is:="+ bFile);
    return bFile;
   }

 }

并确保表列应支持字节数组插入。例如:MYSQL 使用 BLOB 列类型。

As per my understand of question the problem is only inserting file into table. Copy & paste the Change() method into com.srikanth.web.UserAction class as you are using this action for every DB transaction. use Change() method before going to insert/update in DB.

For example:

public class UserAction extends ActionSupport{
   //variable to get file from jsp
   private File uploadedImage;
    .....
   //setters & getters for uploadedImage


@Override
public String gsexecute() throws Exception {

   User user = new User();

   //set image value as byteArray
   user.setImage(Change(uploadedImage));

   //insert or update DB here

    return SUCCESS;
}

 public byte[] Change(File userImage)
   {
   // userImage=this.getUserImage();
   // String name=userImage.getName();
   // long len=userImage.length();

    byte[] bFile = new byte[(int) userImage.length()];
    try {

    FileInputStream fileInputStream = new FileInputStream(userImage);
fileInputStream.read(bFile);
fileInputStream.close();
    }
    catch(Exception e)
    {
        e.printStackTrace();
    }
   // System.out.println("The Name Of File In Pojo Class Is:="+ name);
    //System.out.println("The Length Of File In Pojo Class Is:="+ len);
    //System.out.println("The Content Of File In Pojo Class Is:="+ bFile);
    return bFile;
   }

 }

And make sure that the table column should support the byte array insert. Ex: use BLOB column type for MYSQL.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文