asp.net制作一个表单,需要上传图片到email,然后在Email可以看到图片内容,

asp.net制作一个表单,需要上传图片到email,然后在Email可以看到图片内容,,第1张

给你写了个。

用VS2012开发,支持附件发送。

账户用QQ邮箱发送的话,需要在QQ邮箱中设置SMTP开启,发送时勾选SSL。

满意请给个红包吧^^

首先,文本类的可以放在request中通过requestgetAttribute(name)获取。你在前端放地址,后端也是像前面通过requestgetAttribute(name)获取后存入数据库。这是jsp+servlet的做法。jsp有九大内置对象用于传递数据。而你如果用spring+springmvc的话是通过参数绑定来传递数据的。详细的你可以了解框架文档。建议你选择一种框架可以便捷开发。jsp+servlet是比较原始的处理方式。

获取使用的是$_FILES['new_images'],PHP获取上传使用的是$_FILES这个函数

使用move_uploaded_file($_FILES['new_images']['tmp_name'],"你想要移动到的路径和保存之后的文件名称包含后缀名")这个函数将上传的移动到指定的目录

楼主加油。

第一种:经典的form和input上传。

设置form的aciton为后端页面,enctype="multipart/form-data",type=‘post’

<form action=';

使用input选择文件,设置好其他input的值,点击提交,将文件数据及签名等认证信息发送到form设置的action对应的页面,浏览器也会跳转到该页面。触发form表单提交数据的方式有2种,一种是在页面上点击button按钮或<input

type='submit'>按钮触发,第二种是在js中执行formsubmit()方法。

优点:使用简单方便,兼容性好,基本所有浏览器都支持。

缺点:1 提交数据后页面会跳转(下面会讲如何禁止页面跳转)。

2因为是浏览器发起的请求,不是一个ajax,所以前端无法知道什么时候上传结束。

3 form表单里发送除文件外的数据,一般是新建一个type=hidden的input,value=‘需要传的数据’,每发送一个数据就需要一个input,一旦多了就会使得dom看起来比较冗余。

小技巧:

form表单提交数据后会自动跳转到action指定的页面,为了禁止页面跳转,可以在页面中新建一个空的ifame,比如name='upload',然后设置form的target="Uploader",form有一个target的属性,规定在何处打开action,这样form提交数据后就会仍停留在当前页。代码如下:

<form action=';

这样写的另一个好处是,可以知道什么时候上传完成并接收到后端的回调结果。比如上面这个例子,文件数据发送到了

'uploadFilephp',假设该页面处理完数据后返回了一个地址,该地址会被写入到之前的iframe中。所以在ifame的onload函数触发时,也就是上传完成后,可以在iframe中读取到后端返回的数据。

var  iframe = documentgetElementById('upload1');

iframeonload = function () {  

                    var doc = windowframes['uploader1']document;                    var pre = docgetElementsByTagName('pre');                    var obj = JSONparse(pre[0]innerHTML);

                }

使用这种方法时需要注意,iframe有跨域限制,创建出来的iframe的地址如果和当前页面地址不同源,会报错。这种情况下,建议大家在iframe的onload函数中,再次向后端请求一个接口获取文件地址,而不是直接去iframe里读取。或者返回这样的数据。

<script type="text/javascript">windowtopwindow[callback](data)</script>

callback是和前端约定好的名字,上传完成后触发该函数并返回后端数据。

第二种:使用formData上传。

用js构造form表单的数据,简单高效,但最低只兼容IE10,所以需要兼容IE9的童鞋们就略过这个方法吧。

html:

<input type='file'>

js:

var formData = new FormData();

formDataappend("userid", userid);

formDataappend("signature", signature);

formDataappend("file", file); //file是blob数据//再用ajax发送formData到服务器即可,

注意一定要是post方式上传

说明:第一种方法提到了创建多个type=‘hidden’的input来发送签名数据,这儿可以用formDataappend方法来代替该 *** 作,避免了dom中有多个input的情况出现。最后将file数据也append到formData发送到服务器即可完成上传。

优点:由于这种方式是ajax上传,可以准确知道什么时候上传完成,也可以方便地接收到回调数据。

缺点:兼容性差

第三种:使用fileReader读取文件数据进行上传。

HTML5的新api,兼容性也不是特别好,只兼容到了IE10。

var fr = new FileReader();

                frreadAsDataURL(file);

                fronload = function (event) {                    var data= eventtargetresult; //此处获得的data是base64格式的数据                    imgsrc = data;

                    ajax(url,{data} ,function(){})

                }

上面获得的data可以用来实现上传前的本地预览,也可以用来发送base64数据给后端然后返回该数据块对应的地址。

优点: 同第二种

缺点:一次性发送大量的base64数据会导致浏览器卡顿,服务器端接收这样的数据可能也会出现问题。

下面给你介绍3种web前端上传的方法:

1表单上传

最传统的上传方式是form表单上传,使用form表单的input[type=”file”]控件,打开系统的文件选择对话框,从而达到选择文件并上传的目的。

form表单上传

表单上传需要注意以下几点:

(1)提供form表单,method必须是post。

(2)form表单的enctype必须是multipart/form-data。

(3)提供input type="file"上传输入域。

2ajax上传

ajax和FormData可实现页面无刷新的文件上传效果,主要用到了jQuery的ajax()方法和XML>

FormData接口。通过FormData对象可以更灵活方便的发送表单数据,因为可以独立于表单使用。如果你把表单的编码类型设置为multipart/form-data ,则通过FormData传输的数据格式和表单通过submit()方法传输的数据格式相同。

ajax无刷新上传

Ajax无刷新上传的方式,本质上与表单上传无异,只是把表单里的内容提出来采用ajax提交,并且由前端决定请求结果回传后的展示结果。

3各类插件上传

当上传的需求要求可预览、显示上传进度、中断上传过程、大文件分片上传等等,这时传统的表单上传很难实现这些功能,我们可以借助现有插件完成。

如百度上传插件Web Uploader、jQuery预览插件imgPreview 、拖拽上传与图像预览插件Dropzonejs等等,大家可根据项目实际需求选择适合的插件。

以上就是关于asp.net制作一个表单,需要上传图片到email,然后在Email可以看到图片内容,全部的内容,包括:asp.net制作一个表单,需要上传图片到email,然后在Email可以看到图片内容,、jquery多图片上传(form表单序列化提交)为啥后台只获取一个图片文件、PHP表单中含上传图片的问题,哪里不对等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/10177734.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-06
下一篇2023-05-06

发表评论

登录后才能评论

评论列表(0条)

    保存