标签:
Now in this article I will show how to do Create, Retrieve, Update and Delete (CRUD) operations in MVC4 using AngularJS and WCF REST Services.
The following are the highlights of this article:
- Create a Database. (SchoolManagement).
- Create a Table (Student).
- Create a WCF REST Service Application to do CRUD operations.
- Create a MVC 4 application and use AngularJs to consume WCF REST service.
- Perform the CRUD (Create, Read, Update & Delete) operations.
Angular
AngularJS is a structural framework for dynamic web apps. It lets you use HTML as your template language and lets you extend HTML‘s syntax to express your application‘s components clearly and succinctly. AngularJS is a JavaScript framework. Its goal is to augment browser-based applications with Model–View–Controller (MVC) capability, in an effort to make both development and testing easier.
REST
stands for
Representational State Transfer . This is a protocol for exchanging data over a distributed environment. The main idea behind REST is that we should treat our distributed services as a resource and we should be able to use simple HTTP protocols to perform various operations on that resource.
When we talk about the database as a resource, we usually talk in terms of Create, Retrieve, Update and Delete (CRUD) operations. Now the philosophy of REST is that for a remote resource all these operations should be possible and they should be possible using simple HTTP protocols.
Now the basic CRUD operations are mapped to the HTTP protocols in the following manner:
- GET: Retrieve the required data (representation of data) from the remote resource.
- POST: Update the current representation of the data on the remote server.
- PUT: Insert new data.
- DELETE: Delete the specified data from the remote server.
Now we will go step-by-step.
The following is my data table.
Image 1
The following is the script of my data table:
- CREATE TABLE [dbo].[Student](
- [StudentID] [ int ] IDENTITY(1,1) NOT NULL ,
- [ Name ] [ varchar ](50) NULL ,
- [Email] [ varchar ](500) NULL ,
- [Class] [ varchar ](50) NULL ,
- [EnrollYear] [ varchar ](50) NULL ,
- [City] [ varchar ](50) NULL ,
- [Country] [ varchar ](50) NULL ,
- CONSTRAINT [PK_Student] PRIMARY KEY CLUSTERED
- (
- [StudentID] ASC
- ) WITH (PAD_INDEX = OFF , STATISTICS_NORECOMPUTE = OFF , IGNORE_DUP_KEY = OFF , ALLOW_ROW_LOCKS = ON , ALLOW_PAGE_LOCKS = ON ) ON [ PRIMARY ]
- ) ON [ PRIMARY ]
-
- GO
-
- SET ANSI_PADDING OFF
- GO
So first we need to create the WCF REST Service. So use the following procedure.
Open Visual Studio and select "File" -> "New" -> "Project..." then select WCF in the left Side then select WCF Service Application then click OK.
data:image/s3,"s3://crabby-images/a41c1/a41c1fc2ba75494ba8b130e3a8bf6342689e5e33" alt="技术分享"
Image 2
Now delete the IService.cs and Service.cs files.
data:image/s3,"s3://crabby-images/f7b76/f7b7642682e3840552236be05feb5be75cfa2ad3" alt="技术分享"
Image 3
Now right-click on the project in the Solution Explorer then select Add New Item then select WCF Service then name it as EmployeeService.
data:image/s3,"s3://crabby-images/fd1b5/fd1b5d3deb84718634c548bff523ba881ceab6bd" alt="技术分享"
Image 4
Now I will create a Data Contract as StudentDataContract.
Right-click on the project in the Solution Explorer then select Add New Item then add a .cs file and use the following code:
data:image/s3,"s3://crabby-images/5083b/5083bf2e6d03e6602385f79c1695b68720fd9205" alt="技术分享"
Image 5
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Web;
- using System.Runtime.Serialization;
-
- namespace WCF_REST_Service
- {
- public class StudentDataContract
- {
- [DataContract]
- public class EmployeeDataContract
- {
- [DataMember]
- public string StudentID { get ; set ; }
-
- [DataMember]
- public string Name { get ; set ; }
-
- [DataMember]
- public string Email { get ; set ; }
-
- [DataMember]
- public string Class { get ; set ; }
-
- [DataMember]
- public string EnrollYear { get ; set ; }
-
- [DataMember]
- public string City { get ; set ; }
-
- [DataMember]
- public string Country { get ; set ; }
- }
-
- }
- }
Now it is time to add your database to your application. So create a new folder name as the Model in your project. Now right-click on the Model folder and select Add -> New Item.
data:image/s3,"s3://crabby-images/da0f4/da0f44c3b174a1aaf73781ee9fefa38bba184062" alt="技术分享"
Image 6
Select the ADO.NET Entity Data Model.
data:image/s3,"s3://crabby-images/a9e2f/a9e2ff5313d4b2208dc18cb86c85a796b1569c10" alt="技术分享"
Image 7
data:image/s3,"s3://crabby-images/40c59/40c5959688828f193733b0f4b3f1c15ddd47aa2a" alt="技术分享"
Image 8
Here click on New Connection then enter your SQL Server Details then select your database.
data:image/s3,"s3://crabby-images/3107a/3107a78903b2bef61cad3ef9032a553a8c0bf27f" alt="技术分享"
Image 9
data:image/s3,"s3://crabby-images/17ff8/17ff8a0747232154477cf6f5c1329f755622feaa" alt="技术分享"
Image 10
data:image/s3,"s3://crabby-images/a45c8/a45c8a6517f5ec99dc2170b1a4a1d7b3868097db" alt="技术分享"
Image 11
data:image/s3,"s3://crabby-images/f4ec2/f4ec21143ca9a2c6d5353c33bf49c8c070cfa4ca" alt="技术分享"
Image 12
Now open the IStudentService.cs file to define an interface:
Now make the following changes in your WCF application web.config file:
- <system.serviceModel>
- <behaviors>
- <serviceBehaviors>
- <behavior>
- <!-- To avoid disclosing metadata information, set the values below to false before deployment -->
- <serviceMetadata httpGetEnabled= "true" httpsGetEnabled= "true" />
- <!-- To receive exception details in faults for debugging purposes, set the value below to true . Set to false before deployment to avoid disclosing exception information -->
- <serviceDebug includeExceptionDetailInFaults= "false" />
- </behavior>
- </serviceBehaviors>
- <endpointBehaviors>
- <behavior>
- <webHttp helpEnabled= "True" />
- </behavior>
- </endpointBehaviors>
- </behaviors>
- <protocolMapping>
- <add binding= "webHttpBinding" scheme= "http" />
- </protocolMapping>
- <serviceHostingEnvironment aspNetCompatibilityEnabled= "true" multipleSiteBindingsEnabled= "true" />
- </system.serviceModel>
Now our WCF REST Service is ready; run the WCF REST service.
data:image/s3,"s3://crabby-images/13c74/13c74ebc217509898b15413e3b5a162a0259e2d0" alt="技术分享"
Image 13
It is now time to create a new MVC application. So right-click on your solution and add a new project as below:
data:image/s3,"s3://crabby-images/cfa1b/cfa1be3aa627f6529f9a86ccf1c6d3ec63016484" alt="技术分享"
Image 14
data:image/s3,"s3://crabby-images/64d90/64d90f4206b9f2a7eec6f4efeeaddf82ff269b61" alt="技术分享"
Image 15
data:image/s3,"s3://crabby-images/6a673/6a6739c0d034754f7a06be3bdcd23afec3608b35" alt="技术分享"
Image 16
Now, add your WCF Service URL to your MVC application. You can host your WCF service in IIS or you can run it and discover the URL locally like the following.
Right-click on your MVC project then select Add Service Reference.
data:image/s3,"s3://crabby-images/dedca/dedcaef087cfdc6d5818e523fdb4906e26406e2e" alt="技术分享"
Image 17
data:image/s3,"s3://crabby-images/1fbed/1fbedc5af86fb1987070c9f7d72a677904ae78d6" alt="技术分享"
Image 18
Now it is time to add the AngularJs reference. So right-click on your MVC project name in the Solution Explorer then select Add NuGet Packages.
data:image/s3,"s3://crabby-images/e304e/e304eb60981ab06a2255655bc0ec612a75327d4b" alt="技术分享"
Image 19
data:image/s3,"s3://crabby-images/b9787/b9787d043ae515969a683eed39a3e70b4d53a523" alt="技术分享"
Image 20
Now create a new folder (MyScripts) under the Scripts Folder. Here add the following 3 JavaScript files:
- Modules.JS
- Controllers.JS
- Services.JS
1. Module.JS
- /// <reference path="../angular.min.js" />
- var app;
-
- ( function () {
- app = angular.module( "RESTClientModule" , []);
- })();
2. Controller.JS
- /// <reference path="../angular.min.js" />
- /// <reference path="Modules.js" />
- /// <reference path="Services.js" />
-
- app.controller( "CRUD_AngularJs_RESTController" , function ($scope, CRUD_AngularJs_RESTService) {
-
- $scope.OperType = 1;
- //1 Mean New Entry
-
- GetAllRecords();
- //To Get All Records
- function GetAllRecords() {
- var promiseGet = CRUD_AngularJs_RESTService.getAllStudent();
- promiseGet.then( function (pl) { $scope.Students = pl.data },
- function (errorPl) {
- $log.error( ‘Some Error in Getting Records.‘ , errorPl);
- });
- }
-
- //To Clear all input controls.
- function ClearModels() {
- $scope.OperType = 1;
- $scope.StudentID = "" ;
- $scope.Name = "" ;
- $scope.Email = "" ;
- $scope.Class = "" ;
- $scope.EnrollYear = "" ;
- $scope.City = "" ;
- $scope.Country = "" ;
- }
-
- //To Create new record and Edit an existing Record.
- $scope.save = function () {
- var Student = {
- Name: $scope.Name,
- Email: $scope.Email,
- Class: $scope.Class,
- EnrollYear: $scope.EnrollYear,
- City: $scope.City,
- Country: $scope.Country
- };
- if ($scope.OperType === 1) {
- var promisePost = CRUD_AngularJs_RESTService.post(Student);
- promisePost.then( function (pl) {
- $scope.StudentID = pl.data.StudentID;
- GetAllRecords();
-
- ClearModels();
- }, function (err) {
- console.log( "Some error Occured" + err);
- });
- } else {
- //Edit the record
- debugger ;
- Student.StudentID = $scope.StudentID;
- var promisePut = CRUD_AngularJs_RESTService.put($scope.StudentID, Student);
- promisePut.then( function (pl) {
- $scope.Message = "Student Updated Successfuly" ;
- GetAllRecords();
- ClearModels();
- }, function (err) {
- console.log( "Some Error Occured." + err);
- });
- }
- };
-
- //To Get Student Detail on the Base of Student ID
- $scope.get = function (Student) {
- var promiseGetSingle = CRUD_AngularJs_RESTService.get(Student.StudentID);
- promiseGetSingle.then( function (pl) {
- var res = pl.data;
- $scope.StudentID = res.StudentID;
- $scope.Name = res.Name;
- $scope.Email = res.Email;
- $scope.Class = res.Class;
- $scope.EnrollYear = res.EnrollYear;
- $scope.City = res.City;
- $scope.Country = res.Country;
- $scope.OperType = 0;
- },
- function (errorPl) {
- console.log( ‘Some Error in Getting Details‘ , errorPl);
- });
- }
-
- //To Delete Record
- $scope. delete = function (Student) {
- var promiseDelete = CRUD_AngularJs_RESTService. delete (Student.StudentID);
- promiseDelete.then( function (pl) {
- $scope.Message = "Student Deleted Successfuly" ;
- GetAllRecords();
- ClearModels();
- }, function (err) {
- console.log( "Some Error Occured." + err);
- });
- }
- });
3. Services.JS
Here change the WCF Service URL according to your WCF Service.
- /// <reference path="../angular.min.js" />
- /// <reference path="Modules.js" />
-
- app.service( "CRUD_AngularJs_RESTService" , function ($http) {
- //Create new record
- this .post = function (Student) {
- var request = $http({
- method: "post" ,
- url: "http://localhost:27321/StudentService.svc/AddNewStudent" ,
- data: Student
- });
- return request;
- }
-
- //Update the Record
- this .put = function (StudentID, Student) {
- debugger ;
- var request = $http({
- method: "put" ,
- url: "http://localhost:27321/StudentService.svc/UpdateStudent" ,
- data: Student
- });
- return request;
- }
-
- this .getAllStudent = function () {
- return $http.get( "http://localhost:27321/StudentService.svc/GetAllStudent" );
- };
-
- //Get Single Records
- this .get = function (StudentID) {
- return $http.get( "http://localhost:27321/StudentService.svc/GetStudentDetails/" + StudentID);
- }
-
- //Delete the Record
- this . delete = function (StudentID) {
- var request = $http({
- method: "delete" ,
- url: "http://localhost:27321/StudentService.svc/DeleteStudent/" + StudentID
- });
- return request;
- }
- });
Now add a new controller as in the following:
Right-click on the Controller folder then select Add New.
data:image/s3,"s3://crabby-images/01a31/01a31863c8ca0d2d4dd0c73c6adb2cf8cfe8a0e8" alt="技术分享"
Image 21
data:image/s3,"s3://crabby-images/07483/074836df10bda41f246e2c36b68e067a08864063" alt="技术分享"
Image 22
Now add a View.
Right-click on Index then select "Add View...".
data:image/s3,"s3://crabby-images/39632/396326fd04105b2dce542d7042c860dd9536cba5" alt="技术分享"
Image 23
data:image/s3,"s3://crabby-images/37e10/37e10d8594d92ae3732047c33276f816b6750d2c" alt="技术分享"
Image 24
Now Index.cshtm will be:
It is now time to run the application. To run your view make the following changes in Route.config: data:image/s3,"s3://crabby-images/14dfe/14dfea1a9eb3cf1de0177e6e4b22cf7c5ab5af97" alt="技术分享"
Image 25
Now run application as in the following:
data:image/s3,"s3://crabby-images/48366/483663455eae2c9a3272bfddfe27541b50a3485b" alt="技术分享"
Image 26
data:image/s3,"s3://crabby-images/ffbc7/ffbc7f3d8806c95eed2da353cc3144e1502e8a1f" alt="技术分享"
Image 27
data:image/s3,"s3://crabby-images/a4b55/a4b5531d85efa2536834d432e9b7ed11a455e875" alt="技术分享"
Image 28
CRUD Operations in MVC4 Using AngularJS and WCF REST Services
标签:
原文地址:http://www.cnblogs.com/klsw/p/4774163.html