lưu trữ hàng tháng: Tháng một 2015

HTTP 406 Lỗi khi sử dụng góc $http.get chống lại SharePoint còn lại điểm

Cập Nhật: Marc quảng cáo ndersson chỉ ra này mảnh lớn của thông tin: http://Blogs.Office.com/2014/08/13/JSON-Light-support-Rest-SharePoint-API-Released/. Điều đó giải thích rất nhiều :).

Đó có thể là tên tồi tệ nhất của một bài đăng blog bao giờ! Anyhoo.

Tôi thường làm tất cả của tôi prototyping chống lại một thể hiện O365. Tôi có trường hợp cá nhân của tôi để tôi không cần phải lo lắng về ảnh hưởng đến bất cứ ai khác. Là một sang một bên-nhớ khi chúng tôi gọi mang xung quanh máy ảo trên máy tính xách tay của chúng tôi với RÊU-SQL Server, IIS, quyết định Hyper-V vs. VMWare? Anyhoo...

Tôi đã phát triển một ứng dụng bằng cách sử dụng góc trong môi trường này nào, trong số những thứ khác, Điều này:

$http.Get(serverUrl)
.thành công(chức năng(dữ liệu, tình trạng, tiêu đề, cấu hình) {

var getLinksResponse = dữ liệu;

getLinksResponse.value.forEach(chức năng(theResult) {

// và như vậy và như vậy tuyển

Điều này đã làm việc tốt trong hai khác nhau SharePoint môi trường trực tuyến. Tuy nhiên, Khi đồng nghiệp của tôi chuyển nó đến một trường hợp Cloudshare, ông đã nhận được một HTTP 406 lỗi (đó là lần đầu tiên tôi đã bao giờ nhận rằng một trong những, Vì vậy... yay, Tôi đoán). Chúng tôi đã làm một chút về nghiên cứu và nhận thấy rằng các tiêu đề "Chấp nhận" đã tắt. SharePoint trực tuyến là hoàn toàn hài lòng với:

Chấp nhận: ứng dụng/json

Nhưng trường hợp cloudshare (đó là SP trên prem, được tổ chức trong một máy chủ ảo) muốn cổ điển "odata = tiết" được thêm vào trong là tốt:

Chấp nhận: ứng dụng/json;oData = tiết

Để sửa chữa đó, chúng tôi thêm các tiêu đề như vậy:

var config = {tiêu đề: {
'Chấp nhận': ' ứng dụng/json;oData = tiết '
}
};

$http.Get(serverUrl,cấu hình)
.thành công(chức năng(dữ liệu, tình trạng, tiêu đề, cấu hình) {

var getLinksResponse = dữ liệu;

getLinksResponse.value.forEach(chức năng(theResult) {

// và như vậy và như vậy tuyển

Mà đã thoát khỏi các 406, nhưng nó cũng thay đổi định dạng của các phản ứng. Nó đã nhiều... tiết. (haha!) Nhiều thay đổi được yêu cầu và đây là kết quả cuối cùng:

var config = {tiêu đề: {
'Chấp nhận': ' ứng dụng/json;oData = tiết '
}
};

$http.Get(serverUrl,cấu hình)
.thành công(chức năng(dữ liệu, tình trạng, tiêu đề, cấu hình) {

var getLinksResponse = dữ liệu;

getLinksResponse.d.results.forEach(chức năng(theResult) {

// và như vậy và như vậy tuyển

Điều này chỉ biến thành một 30 Các vấn đề phút cho chúng tôi, Vì vậy chúng tôi lucked. Hy vọng rằng ai đó tìm thấy điều này hữu ích.

</kết thúc>

Làm thế nào để: Sử nhiều góc SharePoint Web phần trên cùng một trang

Blog này bài viết mô tả làm thế nào bạn có thể có nhiều Angular.js dựa SharePoint web phần (tham chiếu thông qua một trình soạn thảo nội dung web phần) trên cùng một trang. Tôi sẽ gọi cho một trình soạn thảo nội dung web phần (CEWP) mà tài liệu tham khảo các JavaScript được xây dựng bằng cách sử dụng khuôn khổ Angular.js một "góc Web phần."

Góc của quá trình bootstrap là siêu dễ dàng và chỉ là về mọi ví dụ mà bạn tìm thấy trên các internets đi một cái gì đó như thế này:

<HTML ng-app = 'myApp'>

<blah /><blah /><blah />

</HTML>

Điều này phá vỡ, Tuy nhiên, Nếu bạn muốn cho phép nhiều CEWP đại diện cho nhiều bộ phận web góc trên cùng một trang. Góc sẽ chỉ tự động bootstrap chống lại chỉ thị của ứng dụng đầu tiên nó tìm thấy – tối thiểu theo góc Phiên bản 1.3.6. Giải pháp là khá đơn giản-theo cách thủ công bootstrap mã của bạn để thay thế. Ở trên bây giờ thay đổi một cái gì đó như thế này:

<cơ thể>
<d
IV id =”bootstrapHere” ng-điều khiển =”myController như theController”>
<blah /><blah /><blah />
</div>
</cơ thể>

<script src =”//Ajax.googleapis.com/Ajax/libs/angularjs/1.3.6/Angular.js”></kịch bản>

<kịch bản>
angular.bootstrap(angular.Element(document.getElementById(“bootstrapHere”)),['myApp']);
</kịch bản>

Về cơ bản, thay vì sử dụng của ứng dụng trên các yếu tố làm bootstrapping của bạn, bạn slap một ID vào yếu tố đó. Sau đó, sử dụng bootstrap() Các phương pháp trên góc riêng của mình để kiểm soát các bootstrapping xử lý tại thời gian chạy. Tôi đã thử nghiệm này với ba bộ phận web góc khác nhau trên cùng một trang và nó hoạt động một nét duyên dáng.

</kết thúc>

undefinedĐăng ký vào blog của tôi.

Theo tôi trên Twitter lúc http://www.twitter.com/pagalvin