写这个纯属是给自己一个记忆啦

一.前台的代码以及调用的js

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title>上传</title>
<script src="jquery-1.4.1.min.js"></script>
<script src="ajaxfileupload.js"></script>
</head>
<body>
<div class="am-u-md-4"> <!-- 文件显示的地方-->
<img id="imgShow1" alt="" class="am-img-circle am-img-thumbnail" src="../../Tools[NO]pic.png" />
</div>
<div class="am-form-group">
<input id="fileUploadChange" runat="server" name="browse" onchange="ajaxFrontCoverUpload1();" style="width: 50%" type="file" />
<input id="fileUploadChangeId" runat="server" type="hidden" value="" /> <!--图片上传--> <!--隐藏一个input存放图片的ID-->
<p class="am-form-help">此处选择要上传的产品大图...</p>
</div>
</body>
</html>
<script>
//异步上传大图
function ajaxFrontCoverUpload1() { //检测要上传的是不是图片文件
var filePath = $("#fileUploadChange").val();
if (filePath != "") {
var extName = filePath.substr(filePath.lastIndexOf('.') + , filePath.length - filePath.lastIndexOf('.'));
if (extName != "jpg" && extName != "bmp" && extName != "png" && extName != "jpeg" && extName != "gif") {
alert("图片必须是bmp,png,jpeg,jpg,gif格式的文件!");
return;
}
}
//上传图片操作
$.ajaxFileUpload
(
{
url: '../UploadImageHandler.ashx',
secureuri: false, //是否需要安全协议
fileElementId: 'fileUploadChange', //上传控件id
type: 'POST',
dataType: "text",
success: function (data) {
var code = data.substring(, );
if (code == "") {
var filePath = data.substring();
filePath = filePath.replace("\\", "/");
$("#fileUploadChangeId").val(filePath);//将文件路径存放在隐藏域中
$("#imgShow1").attr("src", filePath);
alert("上传成功!");
} else {
alert(data);
}
}
}
)
return false;
}
</script>

二.一般处理程序

<%@ WebHandler Language="C#" Class="UploadImageHandler" %>

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Web;
using System.Web.SessionState; public class UploadImageHandler : IHttpHandler { public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
if (context.Request.Files.Count > )
{
HttpPostedFile file = context.Request.Files[];
if (file.ContentLength > )
{
string suffix = file.FileName.Substring(file.FileName.LastIndexOf('.'));//后缀
if (!suffix.ToLower().Contains(".bmp") && !suffix.ToLower().Contains(".png") && !suffix.ToLower().Contains(".jpeg") &&
!suffix.ToLower().Contains(".jpg") && !suffix.ToLower().Contains(".gif"))
{
context.Response.Write("图片格式必须以下格式:bmp,png,jpeg,jpg,gif");
return;
} try
{
string filePath = (@"~/Image/") + DateTime.Now.ToString("yyyyMMdd") + "/" + DateTime.Now.ToString("HHmmssfff");
Directory.CreateDirectory(context.Server.MapPath(filePath));
string fileFullName = filePath + "/" + file.FileName;
file.SaveAs(context.Server.MapPath(fileFullName));
string json = "{\"msg\":\"" + fileFullName + "\",code:\"10000\"}";
context.Response.Write("1_" + fileFullName);
return;
}
catch (Exception ex)
{
context.Response.Write(HttpUtility.HtmlEncode(ex.Message));
return;
}
}
context.Response.Write("请选择要上传的文件!");
return;
}
context.Response.Write("请选择要上传的文件!");
return;
} public bool IsReusable {
get {
return false;
}
} }

无刷新上传图片以及使用C#语言的更多相关文章

  1. nodejs利用ajax实现网页无刷新上传图片

    nodejs利用ajax实现网页无刷新上传图片 标签(空格分隔): nodejs 通常情况下上传图片是要通过提交form表单来实现的,但是这又不可避免的产生了网页转. 利用ajax技术和FormDat ...

  2. php无刷新上传图片和文件

    核心思想:通过Html的iframe标签属性操作顶级窗口,再用php动态无刷新上传图片文件. 示例如下: demo |------uploads #存放上传的文件 |------index.php | ...

  3. 使用SWFUpload无刷新上传图片

    使用SWFUpload组件无刷新上传图片 在做项目时,需要用到一个图片的无刷新上传,之前听说过SWFUpload,于是想要通过SWFUpload来进行图片的无刷新上传,由于我的项目属于是ASP.NET ...

  4. Thinkphp框架 -- ajax无刷新上传图片

    用Thinkphp框架做无刷新上传图片 视图层 View <!doctype html> <html lang="en"> <head> < ...

  5. ajaxFileUpload.js 无刷新上传图片,支持多个参数同时上传,支持 ie6-ie10

    /* 131108-xxj-ajaxFileUpload.js 无刷新上传图片 jquery 插件,支持 ie6-ie10 依赖:jquery-1.6.1.min.js 主方法:ajaxFileUpl ...

  6. TP3.2:实现Ajax无刷新上传图片

    1.基于TP3.2+ajaxfileupload进行无刷新上传图片,本次只上传一张,多张以后搞出来再发 2.效果:   3.html代码: <html> <head> < ...

  7. 无刷新上传图片,ajax 和 iframe

    iframe 上传 upload.html 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 ...

  8. ajax无刷新上传图片

    页面: <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> & ...

  9. js无刷新上传图片,服务端有生成缩略图,剪切图片,iphone图片旋转判断功能

    html: <form action="<{:AppLink('circle/uploadimg')}>" id="imageform" me ...

随机推荐

  1. 关于Unity中的刚体和碰撞器的相关用法(二)

    在关于Unity中的刚体和碰撞器的相关用法(一)的基础上 有一个plane平面,一个ball球体,都挂了碰撞器,ball挂了刚体Rigidbody,写了一个脚本ball挂载在球体上,球体从空中落下装机 ...

  2. SAP ML 物料分类账详解(含取消激活物料帐方法)

    一.业务背景: 中国会计准则规定,对存货的核算必须采用历史成本法(即实际成本法).如果企业采用计划成本法或者定额成本法进行日常核算的,应当按期结转其成本差异,将计划成本或者定额成本调整为实际成本. “ ...

  3. applicationContext.xml报错org.springframework.orm.hibernate3.LocalSessionFactoryBean not found

    applicationContext.xml报错org.springframework.orm.hibernate3.LocalSessionFactoryBean not found 解决办法: 1 ...

  4. (笔记)Linux线程编译undefined reference to 'pthread_create'

    在使用线程时,使用gcc或arm-linux-gcc编译时,会出现错误:undefined reference to 'pthread_create' 主要是以下两种原因: 1.#include &l ...

  5. Spring JDBC JdbcTemplate类示例

    org.springframework.jdbc.core.JdbcTemplate类是JDBC核心包中的中心类.它简化了JDBC的使用,并有助于避免常见的错误. 它执行核心JDBC工作流,留下应用程 ...

  6. e859. 将键盘事件和字符串对应

    The KeyStroke.toString() method does not return a string that can be parsed by KeyStroke.getKeyStrok ...

  7. android 解决输入法键盘遮盖布局问题

    /**     * @param root 最外层布局,需要调整的布局     * @param scrollToView 被键盘遮挡的scrollToView,滚动root,使scrollToVie ...

  8. window wlan 相关服务

    1.Extensible authentication protocol 2.cng key lsolation 3.wlan autoconfig

  9. js中的坑

    for in vs hasOwnProperty == === 对象比较用===,值比较用==. 严格运算用=== http://www.zhihu.com/question/31442029 著作权 ...

  10. 配置防盗链 访问控制Directory 访问控制FilesMatch