Part 33 - Upload and display image using JQuery in Asp.net MVC | To File server - Technotips

Breaking

BANNER 728X90

Saturday, 11 March 2017

Part 33 - Upload and display image using JQuery in Asp.net MVC | To File server


#Expected Output 



#Controller Code(TestController.cs)


using MVCTutorial.Models;
using System;
using System.Collections.Generic;
using System.Globalization;
using System.IO;
using System.Linq;
using System.Threading;
using System.Web;
using System.Web.Mvc;

namespace MVCTutorial.Controllers
{
public class TestController : Controller
{

public ActionResult Index()
{

return View();
}


public JsonResult ImageUpload(ProductViewModel model) {

var file = model.ImageFile;

if (file != null) {

var fileName = Path.GetFileName(file.FileName);
var extention = Path.GetExtension(file.FileName);
var filenamewithoutextension = Path.GetFileNameWithoutExtension(file.FileName);

file.SaveAs(Server.MapPath("/UploadedImage/" + file.FileName));


}

return Json(file.FileName, JsonRequestBehavior.AllowGet);

}
}
}


  
#Model (ProductViewModel.cs) 


using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace MVCTutorial.Models
{
public class ProductViewModel
{
public string ProductName { get; set; }
public string Title { get; set; }
public string Description { get; set; }
public Nullable<int> Price { get; set; }
public Nullable<int> ImageId { get; set; }
public HttpPostedFileWrapper ImageFile { get; set; }
}
}

 # View (Index.cshtml)


@model MVCTutorial.Models.ProductViewModel
@{
ViewBag.Title = "Index";
// Layout = null;
}

<div class="panel panel-body" style="min-height:256px">

@*<div class="col-md-3">

@{ Html.RenderAction("SideMenu", "Test");}

</div>*@
<div class="col-md-9">


<div class="col-md-4">
<div class="btn btn-primary">
<input type="file" id="imageBrowes" />
</div>
<hr />

<div id="imgPreview" class="thumbnail" style="display:none">
<img class="img-responsive" id="targetImg" />
<div class="caption">
<a href="#" onclick="ClearPreview()"><i class="glyphicon glyphicon-trash"></i></a>
<span id="description"></span>
</div>
<a href="#" class="btn btn-default" onclick="Uploadimage()">Upload</a>
</div>

</div>
<div class="col-md-2 thumbnail" id="uploadedImage" >


</div>
</div>


</div>
<script src="~/Scripts/jquery-1.10.2.min.js"></script>
<script>

$(document).ready(function () {

$("#imageBrowes").change(function () {

var File = this.files;

if (File && File[0]) {
ReadImage(File[0]);
}

})

})


var ReadImage = function (file) {

var reader = new FileReader;
var image = new Image;

reader.readAsDataURL(file);
reader.onload = function (_file) {

image.src = _file.target.result;
image.onload = function () {

var height = this.height;
var width = this.width;
var type = file.type;
var size = ~~(file.size / 1024) + "KB";

$("#targetImg").attr('src', _file.target.result);
$("#description").text("Size:" + size + ", " + height + "X " + width + ", " + type + "");
$("#imgPreview").show();

}

}

}

var ClearPreview = function () {
$("#imageBrowes").val('');
$("#description").text('');
$("#imgPreview").hide();

}

var Uploadimage = function () {

var file = $("#imageBrowes").get(0).files;

var data = new FormData;
data.append("ImageFile", file[0]);
data.append("ProductName", "SamsungA8");

$.ajax({

type: "Post",
url: "/Test/ImageUpload",
data: data,
contentType: false,
processData: false,
success: function (response) {
ClearPreview();

$("#uploadedImage").append('<img src="/UploadedImage/' + response + '" class="img-responsive thumbnail"/>');


}

})


//
}

</script>

 # Layout (_Layout.cshtml)


<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>@ViewBag.Title - My ASP.NET Application</title>
@Styles.Render("~/Content/css")
@Scripts.Render("~/bundles/modernizr")

</head>
<body>
<nav class="navbar navbar-inverse navbar-fixed-top">
<div class="container-fluid">
<!-- Brand and toggle get grouped for better mobile display -->
<div class="navbar-header">
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1">
<span class="sr-only">Toggle navigation</span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<a class="navbar-brand" href="/Test/Index">
<img alt="Brand" src="~/Content/Images/logo.png" height="20" width="20">
</a>
</div>

<!-- Collect the nav links, forms, and other content for toggling -->
<div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
<ul class="nav navbar-nav">
<li><a href="#"><span class="glyphicon glyphicon-home"></span></a></li>
<li class="dropdown">
<a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false">Services <span class="caret"></span></a>
<ul class="dropdown-menu" role="menu" id="myTab">
<li role="presentation"><a href="#music" aria-controls="music" role="tab" data-toggle="tab"><span class="glyphicon glyphicon-music"> </span> Music & Dance</a></li>
<li class="divider"></li>
<li role="presentation"><a href="#training" aria-controls="training" role="tab" data-toggle="tab"><span class="glyphicon glyphicon-book"> </span> Summar Training</a></li>
<li class="divider"></li>
<li role="presentation"><a href="#website" aria-controls="website" role="tab" data-toggle="tab"><span class="glyphicon glyphicon-cloud"> </span> Website Building</a></li>
</ul>

</li>
<li><a href="#">About Us</a></li>
<li><a href="#">Career</a></li>
</ul>
<form class="navbar-form navbar-left" role="search">
<div class="form-group">
<input type="text" class="form-control" placeholder="Search">
</div>
<button type="submit" class="btn btn-default">Submit</button>
</form>

@if (Session["UserId"] != null) {

<ul class="nav navbar-nav navbar-right">
<li><a href="#">Welcome :@Session["UserName"] </a></li>
<li><a href="/Test/Logout">Logout</a></li>

</ul>

}
else {
<ul class="nav navbar-nav navbar-right">
<li><a href="/Test/Login">Login</a></li>
<li><a href="/Test/Registration">Register</a></li>

</ul>

}

}

</div>
</div>

</nav>

<div class="panel-body" style="min-height:450px">

@RenderBody()


</div>

<div class="well" style="background-color:#000000;color:wheat;margin-bottom:0px">

<div class="col-lg-4" style="margin-left:20px">

<h3><span class="glyphicon glyphicon-map-marker"></span> Address</h3>
<ul class="list-group list-unstyled">

<li>Technotips Ltd.</li>
<li>xyz Industrial Area</li>
<li>Phase-2,New Delhi-52</li>
</ul>
</div>

<div class="col-lg-4">

<h3><span class="glyphicon glyphicon-cog"></span> Our Services</h3>
<ul class="list-group list-unstyled">

<li><span class="glyphicon glyphicon-music"></span> <a href="#">Musical & Dance Traning</a> </li>
<li><span class="glyphicon glyphicon-book"></span> <a href="#">Training in Asp.Net,Java,android etc.</a></li>
<li><span class="glyphicon glyphicon-globe"></span> <a href="#">Web designing -corporate & Domestic</a> </li>

</ul>
</div>

<div class="col-lg-3">

<h3><span class="glyphicon glyphicon-briefcase"></span> Career</h3>
<ul class="list-group list-unstyled">

<li><span class="glyphicon glyphicon-music"></span> <a href="#">Musical & Dance</a> </li>
<li><span class="glyphicon glyphicon-book"></span> <a href="#">Summar training</a></li>
<li><span class="glyphicon glyphicon-globe"></span> <a href="#">Website Designing</a></li>

</ul>
</div>

<div style="clear:both"></div>


</div>


@Scripts.Render("~/bundles/jquery")
@Scripts.Render("~/bundles/bootstrap")

<script src="~/Scripts/jquery.validate.js"></script>
<script src="~/Scripts/jquery.validate.unobtrusive.min.js"></script>

@RenderSection("scripts", required: false)


</body>
</html>


   

All Code Factory

No comments:

Post a Comment