SharePoint - REST API

ในบทนี้เราจะกล่าวถึง REST API นี่ไม่ใช่ API แบบดั้งเดิมที่เรามีชุดไลบรารีที่มีประเภทและประเภทเหล่านั้นมีคุณสมบัติและวิธีการ

REST API ถูกนำไปใช้เป็นบริการเว็บที่เน้นข้อมูลเป็นศูนย์กลางตาม Open Data Protocol หรือ OData วิธีการทำงานของบริการเว็บเหล่านี้การใช้ทรัพยากรแต่ละรายการในระบบสามารถกำหนดแอดเดรสได้โดย URL เฉพาะที่คุณส่งต่อไปยังเซิร์ฟเวอร์

ให้เราดูสิ่งนี้ใน Internet Explorer ที่ไซต์ SharePoint เปิดอยู่

Step 1 - หากคุณใช้ Internet Explorer ให้ไปที่การตั้งค่า Internet Explorer และบนแท็บเนื้อหาเลือกการตั้งค่าสำหรับฟีดและชิ้นส่วนเว็บดังที่แสดงในภาพหน้าจอด้านล่าง

คุณจะเห็นกล่องโต้ตอบต่อไปนี้ ตรวจสอบให้แน่ใจfeed reading view คือ off แล้วคลิกตกลง

Step 2 - ตอนนี้ให้เราเปลี่ยน URL เป็น URL ของไซต์ + / _ api / web แล้วกด Enter

ตอนนี้คุณควรได้รับมุมมองที่ดูเหมือนภาพหน้าจอต่อไปนี้

เราต้องการข้อมูลเกี่ยวกับเว็บปัจจุบันหรือไซต์ปัจจุบัน ดังนั้น URL ของไซต์ + / _ api จึงเป็น URL พื้นฐานสำหรับ SharePoint 2013 REST API และเว็บคือแบบสอบถามของเรา เราต้องการข้อมูลเกี่ยวกับเว็บปัจจุบัน

เราได้รับเอกสาร XML กลับมาและหากเราเลื่อนลงเราจะได้รับข้อมูลเกี่ยวกับเว็บปัจจุบันของเรา

จากนั้นหากคุณต้องการทราบเกี่ยวกับรายการในเว็บคุณสามารถเพิ่มรายการต่อท้าย URL ของคุณได้ แทนที่จะเป็นข้อมูลเกี่ยวกับวัตถุแต่ละชิ้นเราจะได้รับชุดข้อมูลเกี่ยวกับรายการทั้งหมดในไซต์ปัจจุบัน

เมื่อเราใช้เบราว์เซอร์เรากำลังออกคำขอรับไปยังเซิร์ฟเวอร์ซึ่งหมายความว่าเราต้องการดึงข้อมูล อย่างไรก็ตามเราสามารถดำเนินการ CRUD มาตรฐานที่เหลือได้ด้วย

ดึงทรัพยากรโดยใช้ REST API

SharePoint 2013 REST API ไม่เปิดเผยข้อมูลเมตา ดังนั้นเมื่อเราทำงานกับมันใน Managed Code เราจึงไม่สามารถใช้ Visual Studio เพื่อสร้างพร็อกซีบริการโดยใช้กล่องโต้ตอบการอ้างอิงบริการ แต่เราสามารถใช้ประเภทเช่นเว็บไคลเอนต์ของออบเจ็กต์คำขอเว็บ http เพื่อส่งคำขอไปยังเซิร์ฟเวอร์และรับผลลัพธ์ดิบกลับมา

ไม่ว่าผลลัพธ์เหล่านั้นจะถูกส่งกลับเป็น XML หรือ JSON จะถูกกำหนดโดยส่วนหัวการยอมรับที่เราส่งไปพร้อมกับคำขอ

  • หากเราได้รับ XML กลับมาเราสามารถใช้ LINQ เป็น XML เพื่อดึงข้อมูลจากการตอบสนองที่เราต้องการสำหรับแอปพลิเคชันของเรา

  • หากเราได้รับ JSON กลับมาเราสามารถใช้ JSON แบบอนุกรมต่างๆเพื่อแยกวิเคราะห์ JSON เป็นออบเจ็กต์. NET จากนั้นใช้เพื่อดึงข้อมูลที่เราต้องการ

เมื่อทำงานกับ REST API ใน JavaScript เราสามารถใช้ jQuery หรืออ็อบเจกต์ SP.RequestExecutor เพื่อเรียกใช้บริการ เช่นเดียวกับในตัวอย่าง Managed Code เราสามารถควบคุมได้ว่าจะรับ XML หรือ JSON กลับมาโดยใช้ส่วนหัวยอมรับ เนื่องจากเราทำงานใน JavaScript เป็นส่วนใหญ่เราจึงต้องการคืน JSON

สิ่งที่ควรทราบอีกประการหนึ่งคือเมื่อคุณสร้าง URL ไปยังบริการเราสามารถใช้ไฟล์ _spPageContextInfoวัตถุที่จะได้รับ URL ที่สมบูรณ์จากไซต์จากนั้นเพียงแค่ต่อท้าย URL ของบริการพร้อมกับข้อความค้นหา นี่เป็นเพราะบริการ REST API ไม่เปิดเผยข้อมูลเมตาและคุณไม่สามารถสร้างการอ้างอิงบริการใน Visual Studio การใช้ REST API ใน Managed Code นั้นไม่ใช่การเริ่มต้น

ให้เรามาดูการเรียก REST API จาก JavaScript โดยการสร้างโครงการใหม่

Step 1 - เลือก App for SharePointในบานหน้าต่างตรงกลางและป้อนชื่อโครงการของคุณ คลิกOK.

Step 2 - ป้อน URL ไซต์ของคุณและเลือกไฟล์ SharePoint – hostedแล้วคลิกถัดไป คลิกเสร็จสิ้น

Step 3 - เมื่อสร้างโครงการแล้วให้เราเปิดหน้า Default.aspx ซึ่งอยู่ภายใต้ Pages ใน Solution Explorer และเพิ่มปุ่มเดียว

นี่คือการนำไฟล์ 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 ContentPlaceHolderID = ”PlaceHolderAdditionalPageHead”
   runat = ”server”>
   <script type = ”text/javascript” src = ”../Scripts/jquery-1.9.1.min.js”></script>
   <SharePoint:ScriptLink name = ”sp.js” runat = ”server” OnDemand = ”true”
      LoadAfterUI = ”true” Localizable = ”false” />
   <meta name = ”WebPartPageExpansion” content = ”full” />
   <!–Add your CSS styles to the following file ->
   <link rel = ”Stylesheet” type = ”text/css” href = ”../Content/App.css” />
   <!–Add your JavaScript to the following file ->
   <script type = ”text/javascript” src = ”../Scripts/App.js”></script>
</asp:Content>

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

<asp:Content ContentPlaceHolderID = ”PlaceHolderPageTitleInTitleArea”
   runat = ”server”>
   Page Title
</asp:Content>

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

<asp:Content ContentPlaceHolderID = ”PlaceHolderMain” runat = ”server”>
   <div>
      <p id = ”message”>
         <!–The following content will be replaced with the user name when
            you run the app – see App.js -> initializing…
      </p>
      <input id = ”loadButton” type  = ”button” value = ”Load” />
   </div>
</asp:Content>

Step 4 - เปิดไฟล์ App.js ซึ่งอยู่ภายใต้ Script ใน Solution Explorer และแทนที่ด้วยรหัสต่อไปนี้

JQuery(document).ready(function () {
   JQuery("#loadButton").click(usingLoad)
});

function usingLoad() {
   var context = SP.ClientContext.get_current();
   var web = context.get_web();
   context.load(web);
   context.executeQueryAsync(success, fail);
   
   function success() {
      var message = jQuery("#message");
      message.text(web.get_title());
      message.append("<br/>");
      message.append(lists.get_count());
   }
   function fail(sender, args) {
      alert("Call failed. Error: " + args.get_message());
   }
}

เราใช้ jQuery เพื่อสร้างไฟล์ document.readyฟังก์ชัน ที่นี่เราต้องการแนบตัวจัดการเหตุการณ์การคลิกเข้ากับปุ่ม ดังนั้นเราจึงใช้ตัวเลือกเพื่อรับไฟล์loadButton จากนั้นเราได้เพิ่มตัวจัดการเหตุการณ์คลิกโดยใช้ Load.

ดังนั้นเมื่อเราคลิกปุ่มเราต้องการทำสิ่งเดียวกันกับที่เราทำในเวอร์ชันที่มีการจัดการของการสาธิตเราต้องการแสดงชื่อของเว็บ

Step 5 - เผยแพร่แอปพลิเคชันของคุณแล้วคุณจะเห็นไฟล์ต่อไปนี้ -

Step 6 - ลากไฟล์นี้ไปยังหน้าแอปไซต์ SharePoint ของคุณ

คุณจะเห็นไฟล์ JavaScriptDemo ในรายการ

Step 7- คลิกที่เนื้อหาของไซต์ในบานหน้าต่างด้านซ้ายจากนั้นเลือกเพิ่มแอป คลิกJavaScriptDemo ไอคอน.

Step 8 - คลิก Trust it.

Step 9- ตอนนี้คุณจะเห็นแอปของคุณ คลิกไอคอนแอพ

Step 10 - เมื่อคุณคลิกปุ่มโหลดมันจะอัพเดตข้อความ

คุณสามารถดูข้อความที่อัปเดต