Skip to main content

Featured post

XM Cloud content sync from prod to uat or UAT to prod step by step

When working with Sitecore, it’s common to need content synchronization across environments. Today, I’ll walk you through the steps to sync content from Production to UAT/TEST and vice versa. Steps to Follow 1. Set Up Your Workspace Create a folder on your computer where you will manage the script files and exported data. Open the folder path in PowerShell to begin scripting. We need to run some scripts in PowerShell to update the folder with the basic requirements for syncing content. PS C:\Soft\ContentSync> dotnet new tool-manifest PS C:\Soft\ContentSync> dotnet nuget add source -n Sitecore https://nuget.sitecore.com/resources/v3/index.json PS C:\Soft\ContentSync> dotnet tool install Sitecore.CLI PS C:\Soft\ContentSync> dotnet sitecore cloud login If the above error occurs, you will need to run a different command to resolve the issue. PS C:\Soft\ContentSync> dotnet sitecore init now, Again run above command to open and authenticate with XM Cloud. It will be there a...

AngularJS best practice with WebAPI and MVC

Angular-Js with MVC + Web API
Pagination + Sorting with Angular JS

You may also check : Insert,delete,update,select using angularjs with mvc

Here in this tutorial, we will try to show, How to create ASP.Net MVC project using Angular JS, Create Database in Sql Server and Create WebApi.
I wil going to describe in proper way to Binding the Data in Angular Grid. Here, I am using Entity framework 5.0 .

Step 1:- Create ASP.Net MVC Project with VS2013
       
           1. Open your VS IDE 2013
           2. Go to file menu and select New  
           3. Click on create Project
           4. Asp.Net Web Application
               Select MVC template, Click on Add button, Give name as DemoApp.

               Now your MVC project is ready to go for next process.

Step 2:- Create Database and Demo Table Student with some data.

1.    Open your Sql Server
2.    Create a database name as DemoDb by using command Create database DemoDb
3.     Now your database is ready.
4.    Create a table into database by clicking on table folder from DemoDb(Database).

To create table use the following below code.

CREATE TABLE [dbo].[Student](
 [StudentId] [nvarchar](10) NOT NULL,
 [FirstName] [nvarchar](50) NULL,
 [LastName] [nvarchar](50) NULL,
 [Age] [int] NULL,
 [Gender] [nvarchar](50) NULL,
 [Batch] [nvarchar](50) NULL,
 [Address] [nvarchar](50) NULL,
 [Class] [nvarchar](50) NULL,
 [School] [nvarchar](50) NULL,
 [Domicile] [nvarchar](50) NULL,

) 
To insert some data in table use the following below code.
INSERT INTO [dbo].[Student]
           ([StudentId]
           ,[FirstName]
           ,[LastName]
           ,[Age]
           ,[Gender]
           ,[Batch]
           ,[Address]
           ,[Class]
           ,[School]
           ,[Domicile])
     VALUES
           (1,
           'Rahul','Patankar',
           24,'Male','27','Sambhajinagar','10','Godavari Public School','Sambhajinagar'),
     (2,
           'Dnyanesh','Kunde',
           24,'Male','15','Hyderabad','10','Hyderabad Public School','Hyderabad'),
     (3,
           'Shailesh','Wagh',
           24,'Male','10','Sambhajinagar','10','Godavari Public School','Sambhajinagar'),
     (4,
           'Arjun','Shinde',
           26,'Male','17','Sambhajinagar','10','A.K Waghmare','Sambhajinagar'),
     (5,
           'Sayali','Wavikar',
           23,'Female','27','Sambhajinagar','10','Godavari Public School','Sambhajinagar'),
     (6,
           'Sumeet','Chautmal',
           24,'Male','22','Sambhajinagar','10','Godavari Public School','Sambhajinagar')
         
GO


Step 3:- Add Entity Data Model into your project 

1. Select and Right click on Model folder
2. Select  Add
3. Go to New Item
4. In search box, enter Entity Data Model and add it by giving Name as StudentModel.
5. After clicking on add button you able to see one window, Now click on EF designer from   database and press Next.
6. Now you need to create new database connection and fill the information reqd. by clicking on New Db connection.
7. Click on test connection.
   

Step 4:- Creating Web Api project in the same solution name as DemoApp

1. Right Click on Solution Name
2. Click on Add
3. New Project
4. Select Asp.Net Web app
5. Create Name as DemoApp.Api

Select Web API Template and Click on OK.

Here, I am binding the data from Our Database DemoDb with Angular Grid into our MVC Application DemoApp by using Web Api.
So it is required to write some logic to interact with our Database DemoDb and Performing reqd. operations.

Add the reference of DemoApp MVC projects ref.to DemoApp.Api.
By Right Clicking on refereces => add ref. => select reqd. project =>click on Ok.

Note:- Plese Copy the Connection string from your DemoApp web.config file and Paste it into web.config of DemoApp.Api Project.

So, to implement this follow below steps.
                     1. Right Click on Controller Folder into DemoApp.Api project
                     2. Click on Add Controller
                     3. Select Empty Controller and click on add.
                     4. Give name as DemoApiController. Just Copy and Paste the below Code.

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

namespace DemoApp.Api.Controllers
{

    [RoutePrefix("api/DemoApi")]
    public class DemoApiController : ApiController
    {
        Private DemoDbEntities db = new DemoDbEntities();
        [Route("GetStudents")]
        public IEnumerable GetStudents()
        {
            return db.Students.AsEnumerable();
        }
        [Route("GetStudentsAsc")]
        public IEnumerable GetStudentsAsc()
        {
            return db.Students.AsEnumerable().OrderBy(x=>x.StudentId);
        }
        [Route("GetStudentsDesc")]
        public IEnumerable GetStudentsDesc()
        {
            return db.Students.AsEnumerable().OrderByDescending(x => x.StudentId);
        } 
    }
}

config.Formatters.JsonFormatter.SupportedMediaTypes.Add(new MediaTypeHeaderValue("text/html"));

Step 5 :- Using Web Api (DempApp.Api) into Web Application (DemoApp).

Now move to DemoApp( MVC web app project),
              1. In DemoApp, Right click on Controller Folder
              2. Add Controller
              3. Select Empty Controller Give name as DemoController
              4. Your controller Should look like below :-

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

namespace DemoApp.Controllers
{
    public class DemoController : Controller
    {
        // GET: Demo
        public ActionResult Index()
        {
            return View();
        }
    }
}
  5. Right Click on Index Action and Add Empty View.
               6. Right Click on Scripts folder into DemoApp
               7. Add new Javascript file Give name as App.js and add below code into it.
var app = angular.module('app', ['ngTouch', 'ui.grid', 'ui.grid.pagination']);
app.controller('MainCtrl', [
'$scope', '$http', 'uiGridConstants', function ($scope, $http, uiGridConstants) {
    var paginationOptions = {
        pageNumber: 1,
        pageSize: 10,
        sort: null
    };
    $scope.gridOptions = {
        paginationPageSizes: [10, 20, 30,40,50,60,70,80,90],
        paginationPageSize: 10,
        useExternalPagination: true,
        useExternalSorting: true,
        columnDefs: [
        { name: 'StudentId' },
        { name: 'FirstName', enableSorting: false },
        { name: 'LastName', enableSorting: false },
        { name: 'Age', enableSorting: false },
        { name: 'Gender', enableSorting: false },
        { name: 'Batch', enableSorting: false },
        { name: 'Address', enableSorting: false },
        { name: 'Class', enableSorting: false },
        { name: 'School', enableSorting: false },
        { name: 'Domicile', enableSorting: false },
        ],
        onRegisterApi: function (gridApi) {
            $scope.gridApi = gridApi;
            $scope.gridApi.core.on.sortChanged($scope, function (grid, sortColumns) {
                if (sortColumns.length == 0) {
                    paginationOptions.sort = null;
                } else {
                    paginationOptions.sort = sortColumns[0].sort.direction;
                }
                getPage();
            });
            gridApi.pagination.on.paginationChanged($scope, function (newPage, pageSize) {
                paginationOptions.pageNumber = newPage;
                paginationOptions.pageSize = pageSize;
                getPage();
            });
        }
    };
    var getPage = function () {
        var url;
        switch (paginationOptions.sort) {
            case uiGridConstants.ASC:
//URL of your Web Api running Path.
                url = 'http://localhost:57868/api/DemoApi/GetStudentsAsc';
                break;
            case uiGridConstants.DESC:
//URL of your Web Api running Path.
                url = 'http://localhost:57868/api/DemoApi/GetStudentsDesc';
                break;
            default:
//URL of your Web Api running Path.
                url = 'http://localhost:57868/api/DemoApi/GetStudents';
                break;
        }

        $http.get(url)
        .success(function (data) {
            $scope.gridOptions.totalItems = 100;
            var firstRow = (paginationOptions.pageNumber - 1) * paginationOptions.pageSize;
            $scope.gridOptions.data = data.slice(firstRow, firstRow + paginationOptions.pageSize);
        });
    };

    getPage();
}
]);

After adding the Script as App.js into your scripts folder, add the below code into your view i.e. Index.cshtml.








  


              


        
Now everything is done. Just need to do some settings as below. 1. Set Multiple project Startup to start WebApp and WebApi project parallel. 1. Now Right click on solution 2. Set as startup project 3. Click on button multiple project 4. Choose both project as start. 2. To Give Cross Origin Resource Sharing (CORS)
<system.webServer>
<httpprotocol>
      <customheaders>
        <add name="Access-Control-Allow-Origin" value="*">
        <add name="Access-Control-Allow-Headers" value="Content-Type">
        <add name="Access-Control-Allow-Methods" value="GET, POST, PUT, DELETE, OPTIONS">
      </add></add></add></customheaders>
    </httpprotocol>
</system.webServer>

Comments

Popular posts from this blog

How to use Nmap with example

  Nmap is a popular open source network scanning tool used for network exploration, security auditing, and vulnerability testing. Here's an example of how to use Nmap: Open a command prompt or terminal window on your computer. Type "nmap" followed by the IP address or domain name of the target network or device that you want to scan. For example, to scan a website, you might enter: nmap www.example.com Hit enter to start the scan. Nmap will begin probing the target network or device and will display information about the discovered hosts and open ports. You can use various options and flags to customize the scan. For example, the "-sS" flag specifies a TCP SYN scan, which is a stealthy scan method that can bypass some firewall configurations. The "-p" flag specifies the ports to scan. For example, to scan only ports 80 and 443 on a website, you might enter: nmap -sS -p 80,443 www.example.com Hit enter to start the customized scan. Nmap will d...

How to become sitecore architect

  Becoming a Sitecore architect requires a combination of technical skills and experience working with Sitecore. Here are the steps you can follow to become a Sitecore architect: Acquire Sitecore certifications: Sitecore offers a range of certifications, including Sitecore Certified Developer, Sitecore Certified Solution Architect, and Sitecore Certified Master. These certifications will demonstrate your expertise in Sitecore and give you credibility in the industry. Gain practical experience: To become a Sitecore architect, you will need to have hands-on experience working with Sitecore. This could include building and deploying Sitecore websites, working with Sitecore modules and components, and troubleshooting issues. You can gain this experience through work experience, personal projects, or Sitecore sandbox environments. Learn related technologies: Sitecore architects need to have a solid understanding of related technologies, such as .NET, SQL Server, and front-end developmen...

How to Setting up local development environment with XM Cloud and containers

   To set up a local development environment with XM Cloud and containers, you will need to follow these steps: Install Docker: Docker is a containerization platform that allows you to run applications in isolated containers. Install Docker on your local machine. Install Docker Compose: Docker Compose is a tool that allows you to define and run multi-container Docker applications. Install Docker Compose on your local machine. Create a Docker Compose file: Create a Docker Compose file that defines the services you want to run. In this case, you will need to define a service for XM Cloud. Configure XM Cloud: In the Docker Compose file, configure the XM Cloud service by defining the necessary environment variables, such as your XM Cloud API key and secret. Build the containers: Build the containers by running the "docker-compose build" command. This will create a Docker image for the XM Cloud service. Start the containers: Start the containers by running the "docker-compose...

How to use HTTPort

  HTTPort is a tool that allows you to tunnel TCP/IP connections through HTTP proxies. Here's how you can use it: Download and install HTTPort on your computer. Launch HTTPort and configure the settings. In the "Server" section, enter the address and port of the HTTP proxy that you want to use. In the "Listen" section, enter the local port on your computer that you want to use to connect to the proxy. Click the "Start" button to begin the tunneling process. HTTPort will create a TCP/IP tunnel between your computer and the proxy server. Configure your client software to use the local port that you specified in step 2 as the proxy server. For example, if you want to use a web browser to browse the web through the HTTP proxy, you would configure the browser to use "localhost" and the local port as the proxy server. Use your client software as you normally would. HTTPort will handle the tunneling of the TCP/IP connection through the HTT...

Denial of Service (DoS) attack

  A Denial of Service (DoS) attack is a type of cyber attack that targets computer systems or networks by overwhelming them with a flood of traffic, thereby preventing legitimate users from accessing the system or network. DoS attacks are typically carried out using botnets, which are networks of compromised computers that are controlled by a hacker. Here's an example of a DoS attack: Suppose an attacker wants to disrupt the operations of a popular e-commerce website during the holiday shopping season. They could launch a DoS attack against the website's servers, flooding them with a massive amount of traffic and requests. The attacker could use a botnet to generate the traffic, using techniques such as IP spoofing or amplification to make the traffic appear to come from many different sources. The traffic flood will quickly overwhelm the web servers and prevent legitimate users from accessing the website, leading to loss of revenue and reputation damage for the e-commerc...