php怎么用ajax弹出笑脸,用Ajax图片上传、预览、修改图片(示例代码)

首选图片的上传和下载并不是很难,但要注意细节。

一,给出前端图片上传的html代码

1.图片上传的控件

请选择文件

上传图片要注意给出默认图片,提交按钮是btton、并不是submit ,属性是enctype="multipart/form-data" 这样后台才能接收到上传的文件。

2.图片上传的js

(1)首次加载的js

$.ajax({

url:\'dy_firstget_image.jspx\',

type:\'get\',

data:{recid:str},

success:function(info){

$(\'.backimg\').attr(\'src\',JSON.parse(info).msg)

console.log(info)

},

error:function(err,errmsg){

console.log(errmsg)

}

})

(2)点击上传时的js

functiongosubmit(){var formdata=newFormData();//formdata.append(\'name\', \'uploadImage\');

formdata.append(\'uploadImage\',$(\'#uploadImage\').get(0).files[0]);

formdata.append(\'recid\',str);

$.ajax({

url:\'dy_upload_image.jspx\',

type:\'post\',

contentType:false,

data:formdata,

processData:false,

success:function(info){

console.log(info)

$(\'.backimg\').attr(\'src\',JSON.parse(info).msg);

},

error:function(err){

console.log(err)

}

});

}

这里用到了formdata ,我理解的是用ajax 提交的方式将表单提交上去,因为form表单正常submit提交会跳到下一个界面。用ajax提交可以在本页面预览图片,用户体验很好。

把图片数据放到fordata中注意上面红色js的代码,是后面controller接到数据的关键。

先把图片挂上去,昨天的成果(笑脸)

48c05f5507be408a9e9a0d1df3c72465.jpg

3,后台接收图片的controller(首次加载图片,如果没有图片则显示默认图片)

/*** 首次加载预览图片

*@paramrequest

*@paramresponse

*@paramimageName*/@RequestMapping(value= "/dy_firstget_image.jspx", method =RequestMethod.GET)public voiddy_firstget_image(HttpServletRequest request, HttpServletResponse response,

@RequestParam(value= "recid", required = false) String recid) {

response.setContentType("image/jpeg");if(!StringUtils.isEmpty(recid)){

BaseInfoManageBean baseBean=cmsDyUploadImageDaoImpl.getDXYQSBImageByid(recid);//根据id查询该仪器的图片,如果不为空则返回图片url

if(!StringUtils.isEmpty(baseBean.getPhoto())){

ResponseUtils.renderText(response, DyUtils.getJSONString(0, baseBean.getPhoto()));

}

}

}

4,上传图片方法

/*** 上传图片、并且把照片url存储到大型仪器表中

*@paramrequest

*@paramresponse

*@paramfile

*@paramrecid*/@RequestMapping(value= "/dy_upload_image.jspx", method =RequestMethod.POST)public voiddy_upload_image(HttpServletRequest request, HttpServletResponse response,

@RequestParam(value= "uploadImage", required = false) MultipartFile file,

@RequestParam(value= "recid", required = false) String recid) {if(file!=null){

String imageUrl=cmsDyUploadImageDaoImpl.saveImage(file, recid);if(imageUrl!=null){

ResponseUtils.renderText(response, DyUtils.getJSONString(0, imageUrl));return;

}

}

ResponseUtils.renderText(response, DyUtils.getJSONString(1, "图片上传失败"));

}

上传成功后返回imageUrl 赋值到img控件上面

5,预览图片方法

/*** 预览图片

*@paramrequest

*@paramresponse

*@paramimageName*/@RequestMapping(value= "/dy_get_image.jspx", method =RequestMethod.GET)public voiddy_get_image(HttpServletRequest request, HttpServletResponse response,

@RequestParam(value= "imageName", required = false) String imageName) {

response.setContentType("image/jpeg");try{

StreamUtils.copy(new FileInputStream(new File(DyUtils.IMAGE_DIR+imageName)), response.getOutputStream());

}catch(IOException e) {

e.printStackTrace();

ResponseUtils.renderText(response, DyUtils.getJSONString(1, "读取图片失败"));

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值