با سلام و عرض ادب
در قسمتی از سایت ما نیاز به آپلود عکس داریم و میخوایم کاربر صفر کیلومتر هم درگیر کوچک کردن عکس و این چیزا نشه چنین کدی اماده کردم اما باز جواب نمیده و عکس 4 مگا بایتی کامل به سرور ارسال میشه و زمان بره تا آپلود بشه میخوام فقط سرعت ارسال به سرور افزایش پیدا کنه و گرنه سمت سرور بخوام کم کنم حجمش رو مشکلی نداره
کد HTML:
<asp:fileupload id="FileUpload1" runat="server" />
<asp:requiredfieldvalidator controltovalidate="FileUpload1" runat="server" id="RequiredFieldValidator6" errormessage="" validationgroup="j1" display="Dynamic" text="" setfocusonerror="True"></asp:requiredfieldvalidator>
<input type="button" value="برای انتخاب دوبار کلیک کنید" onclick="ResizeImage()" />
<asp:HiddenField ID="HiddenField1" runat="server" />
<img width="200" height="200" src="" runat="server" id="output">
<asp:Button ID="Button1" runat="server" Text="Button" OnClick="Button1_OnClick" />
<script type="text/javascript">
function ResizeImage() {
if (window.File && window.FileReader && window.FileList && window.Blob) {
var file = document.getElementById('<%=FileUpload1.ClientID%>').files[0];
if (file) {
var reader = new FileReader();
// Set the image once loaded into file reader
reader.onload = function (e) {
var img = document.createElement("img");
img.src = e.target.result;
var canvas = document.createElement("canvas");
var ctx = canvas.getContext("2d");
ctx.drawImage(img, 0, 0);
var MAX_WIDTH = 300;
var MAX_HEIGHT = 300;
var width = img.width;
var height = img.height;
if (width > height) {
if (width > MAX_WIDTH) {
height *= MAX_WIDTH / width;
width = MAX_WIDTH;
}
} else {
if (height > MAX_HEIGHT) {
width *= MAX_HEIGHT / height;
height = MAX_HEIGHT;
}
}
canvas.width = width;
canvas.height = height;
var ctx = canvas.getContext("2d");
ctx.drawImage(img, 0, 0, width, height);
dataurl = canvas.toDataURL(file.type);
document.getElementById('<% =HiddenField1.ClientID%>').value= document.getElementById('output').src = dataurl;
}
reader.readAsDataURL(file);
}
} else {
alert('مرورگر شما چنین کدی را ساپورت نمی کند.');
}
}
</script>
و سمت سرور
int width = 300;
int height = 300;
byte[] image1;
try
{
image1 = Convert.FromBase64String(HiddenField1.Value.Replac e("data:image/jpeg;base64,", ""));
}
catch
{
image1 = Convert.FromBase64String(HiddenField1.Value.Replac e("data:image/png;base64,", ""));
}
using (MemoryStream mem = new MemoryStream(image1))
{
Stream stream = mem;
Bitmap image = new Bitmap(stream);
Bitmap target = new Bitmap(width, height);
Graphics graphic = Graphics.FromImage(target);
graphic.DrawImage(image, 0, 0, width, height);
target.Save(Server.MapPath(@"~/up/" + FileUpload1.FileName));
}