SharePoint-앱

이 장에서는 SharePoint 앱을 다룰 것입니다. 앱 모델은 SharePoint 확장을위한 새로운 개발 배포 및 호스팅 모델입니다. SharePoint 2013의 개발자는 솔루션 모델 (팜 또는 샌드 박스 솔루션)을 사용하거나 앱 모델을 사용할 수 있습니다.

Microsoft 설명서 및 지침에 따르면 솔루션 모델보다 앱 모델을 선호하며 이는 매우 유효한 지침 일 수 있습니다. 그러나 솔루션 모델은 SharePoint 2007 이후로 존재하는 동안 SharePoint 2013에 중요한 추가 기능인 앱 모델을 고려해야합니다.

따라서 솔루션 모델을 사용한 개발을위한 지식 기반은 앱 개발을위한 현재의 지식 기반 상태보다 훨씬 낫습니다.

앱은 사람들이이를 사용하여 실제 경험을 공유 할 수있을만큼 오래되지 않았습니다. 앱 모델과 장단점을 배우는 것이 매우 중요하다고 생각합니다.

앱 특성

앱 특성은 다음과 같습니다.

  • 개발자 관점에서 볼 때 첫 번째이자 아마도 가장 중요한 것은 앱의 모든 코드가 SharePoint 서버 외부에서 실행된다는 것입니다. 이는 코드가 사용자의 브라우저에서 실행되는 JavaScript이거나 일부 외부 서버에서 실행되는 코드임을 의미합니다.

  • 모든 코드가 SharePoint 외부에서 실행되기 때문에 SharePoint와의 통신은 웹 서비스를 통해 이루어집니다. 즉, 클라이언트 개체 모델 또는 REST API를 사용하고 있습니다.

  • SharePoint 앱에서 서버 개체 모델을 사용할 수있는 상황은 없습니다.

  • 앱 빌드를 마치면 공개 앱 스토어 또는 로컬 앱 카탈로그에 넣습니다. 이를 위해서는 검토 프로세스가 필요하며 앱이 공개 앱 스토어에 들어갈 수 있도록하기 위해 따라야하는 몇 가지 규칙이 있습니다.

  • 다른 옵션은 앱을 중앙 관리에서 앱 카탈로그로 구성한 웹 애플리케이션 내의 사이트 모음 인 로컬 앱 카탈로그에 앱을 배치하는 것입니다.

  • 앱이 카탈로그 저장소에 배포되면 사이트 모음 소유자 권한이있는 사용자가 SharePoint 사이트에 앱을 설치할 수 있습니다.

앱 유형

다음과 같이 빌드 할 수있는 다양한 유형의 앱이 있습니다.

SharePoint 호스팅 앱

첫 번째는 SharePoint 호스팅 앱입니다. 이름에서 알 수 있듯이 이러한 종류의 앱은 SharePoint 팜에서 호스팅됩니다.

중요한 기능은-

  • 설치된 사이트의 하위 사이트에서 호스팅되며이 하위 사이트는 다른 사이트와 마찬가지로 대부분의 경우 작동합니다.

  • 여기에는 목록, 라이브러리, 페이지, 콘텐츠 유형 등이 포함될 수 있습니다.

  • SharePoint 호스팅 앱 구축의 기본 사항은 SharePoint 솔루션 구축의 기본 사항과 유사합니다.

    • 기능이 있습니다.

    • 해당 기능에 요소를 추가 할 수 있으며 해당 요소는 CAML을 사용하여 정의됩니다.

    • 많은 요소의 경우 Visual Studio에 디자이너가 있습니다.

    • 사이트 페이지를 추가 할 수 있습니다.

    • 해당 사이트 페이지에 서버 컨트롤을 추가 할 수 있습니다.

    • 이러한 사이트 페이지 뒤에 코드를 추가 할 수는 없지만 JavaScript 코드는 추가 할 수 있습니다.

    • 이제 기본을 넘어 서면 상황이 점점 더 비슷해지기 시작합니다.

클라우드 호스팅 앱

다른 두 가지 유형의 앱인 Provider-Hosted 및 Auto-Hosted는 함께 클라우드 호스팅 앱으로 분류됩니다. 중요한 기능은-

  • 이러한 앱은 SharePoint 외부 사이트에 있습니다.

  • Provider-Hosted와 Auto-Hosted의 큰 차이점은 누가이 외부 사이트를 만들고 관리 할 것인가입니다.

    • 공급자 호스팅 앱에서 즉, 귀하 또는 귀하의 조직입니다.

    • 자동 호스팅 앱에서는 Microsoft입니다.

  • 클라우드 호스팅 앱 구축은 다른 웹 사이트 구축과 동일합니다.

  • .NET 개발자 인 경우 MVC 또는 Web Forms를 사용하고있을 것입니다. 그러나 이러한 기술에 국한되지 않습니다. 원하는 웹 기술로 클라우드 호스팅 앱을 구축 할 수 있습니다. 앱 빌드를 마치면 공급자 호스팅 시나리오에서 다른 웹 사이트에서와 같은 방식으로 앱을 사이트에 배포합니다.

  • 자동 호스팅 시나리오에서는 Visual Studio를 사용하여 앱 패키지를 만듭니다. 솔루션 패키지에 해당하는 앱이므로 SharePoint Online 및 사이트에 업로드 할 수 있습니다. 필요한 경우 앱을 호스팅 할 수 있도록 데이터베이스가 프로비저닝됩니다.

  • 자동 호스팅 된 앱은 SharePoint Online에서만 사용할 수 있으며 온-프레미스 팜에서는 지원되지 않습니다.

다음은 앱 모델 장에서 이미 다룬 동일한 예입니다.

Visual Studio를 열고 파일 → 새로 만들기 → 프로젝트 메뉴 옵션을 선택하여 SharePoint에서 호스팅하는 응용 프로그램의 간단한 예를 살펴 보겠습니다.

Step 1 − Visual Studio를 열고 File → New → Project menu.

Step 2 − 왼쪽 창에서 Templates → Visual C# → Office/SharePoint 그런 다음 가운데 창에서 App for SharePoint.

이름 필드에 이름을 입력하고 확인을 클릭하면 다음 대화 상자가 표시됩니다.

SharePoint 용 새 앱에서 디버깅 할 SharePoint 사이트 URL을 추가 한 다음 SharePoint 용 앱을 호스팅 할 방식으로 SharePoint 호스팅 모델을 선택해야합니다.

Step 3 − SharePoint 관리 센터로 이동하여 SharePoint URL을 복사합니다.

Step 4 − URL을 New App for SharePoint 아래와 같이 대화 상자.

Step 5 − 클릭 Next 그리고 그것은 열립니다 Connect to SharePoint 로그인해야하는 대화 상자.

Step 6 − 자격 증명을 입력하고 Sign in단추. SharePoint 사이트에 성공적으로 로그인하면 다음 대화 상자가 나타납니다.

Step 7 − 클릭 Finish. 프로젝트가 생성되면AppMenifest.xml 솔루션 탐색기에서 파일.

Step 8 − 클릭 Permissions탭. 범위 드롭 다운 목록이 열립니다.

Step 9 − 범위 드롭 다운 목록에서 Web, 구성중인 권한의 범위입니다. 권한 드롭 다운 목록에서 구성중인 권한 유형 인 읽기를 선택합니다.

Step 10 − Default.aspx 파일을 열고 다음 코드로 바꿉니다.

<%-- The following 4 lines are ASP.NET directives needed when 
   using SharePoint components --%>

<%@ Page Inherits = "Microsoft.SharePoint.WebPartPages.WebPartPage,
   Microsoft.SharePoint, Version = 15.0.0.0, Culture = neutral,
   PublicKeyToken = 71e9bce111e9429c" MasterPageFile = "~masterurl/default.master"
   Language = "C#" %>

<%@ Register TagPrefix = "Utilities" Namespace = "Microsoft.SharePoint.Utilities"
   Assembly = "Microsoft.SharePoint, Version = 15.0.0.0, Culture = neutral,
   PublicKeyToken = 71e9bce111e9429c" %>

<%@ Register TagPrefix = "WebPartPages"
   Namespace = "Microsoft.SharePoint.WebPartPages" Assembly = "Microsoft.SharePoint,
   Version = 15.0.0.0, Culture = neutral, PublicKeyToken = 71e9bce111e9429c" %>

<%@ Register TagPrefix = "SharePoint"
   Namespace = "Microsoft.SharePoint.WebControls" Assembly = "Microsoft.SharePoint,
   Version = 15.0.0.0, Culture = neutral, PublicKeyToken = 71e9bce111e9429c" %>

<%-- The markup and script in the following Content element 
   will be placed in the <head> of the page --%>

<asp:Content ID = "Content1" ContentPlaceHolderID = "PlaceHolderAdditionalPageHead" 
   runat = "server">
   <script type = "text/javascript" src = "../Scripts/jquery- 1.6.2.min.js"></script>
   <link rel = "Stylesheet" type = "text/css" href = "../Content/App.css" />
   <script type = "text/javascript" src = "../Scripts/App.js"></script>
</asp:Content>

<asp:Content ID = "Content2" ContentPlaceHolderID = "PlaceHolderMain"
   runat = "server">
   <script type = "text/javascript"> 
      function hello() {
         var currentTime = new Date();
         $get("timeDiv").innerHTML = currentTime.toDateString();
      }
   </script>
   <div id = "timeDiv"></div>
   <input type = "button" value = "Push me!" onclick = "hello();" />
</asp:Content>

Step 11− 솔루션 탐색기로 이동하여 프로젝트를 마우스 오른쪽 버튼으로 클릭하고 게시를 선택합니다. 클릭Package the app단추. 이렇게하면 SharePoint 호스팅 앱이 빌드되고 SharePoint 사이트에 배포 할 수 있도록 준비됩니다.

* .app 파일이 포함 된 다음 폴더가 표시됩니다.

Step 12 − SharePoint 온라인 사이트로 이동합니다.

Step 13 − 클릭 Apps for SharePoint왼쪽 창에서. 새 페이지가 열립니다.

Step 14 − 업로드하려면 여기로 파일을 드래그하세요.

파일이 업로드되면 다음 페이지가 표시됩니다.

Step 15 − 옵션 클릭- Site Contents왼쪽 창에서. 클릭add an app 다음 스크린 샷과 같이 아이콘-

새 페이지가 열립니다.

Step 16 − 선택 Your Apps → From Your Organization왼쪽 창에서 앱을 설치할 수 있음을 알 수 있습니다. 앱을 클릭하십시오.

Step 17− 앱을 클릭하면 다음 스크린 샷과 같은 대화 상자가 열립니다. 딸깍 하는 소리Trust it.

Step 18− 앱이 설치된 것을 확인할 수 있습니다. 설치가 완료되면 앱을 클릭 할 수 있습니다.

하나의 버튼이 포함 된 다음 페이지가 표시됩니다.

클릭하면 Push me 버튼을 누르면 현재 날짜가 표시됩니다.

자동 호스팅

다음의 간단한 예를 살펴 보겠습니다. Autohosted 새 프로젝트를 생성합니다.

Step 1 − 선택 App for SharePoint 2013 클릭 OK.

Step 2 − Autohosted를 선택합니다.

Step 3 − ASP.NET MVC 웹 응용 프로그램을 선택하고 마침을 클릭합니다.

프로젝트가 생성되면 앱을 게시합니다. 나머지 단계는 SharePoint 호스팅 옵션에 대해 제공된 것과 동일합니다.