Apps Script sử dụng hộp cát bảo mật để cung cấp khả năng cách ly bảo vệ cho các ứng dụng Google Workspace trong một số trường hợp. Tất cả các chế độ hộp cát hiện đã ngừng hoạt động, ngoại trừ IFRAME
. Các ứng dụng sử dụng chế độ hộp cát cũ hiện sẽ tự động sử dụng chế độ IFRAME
mới hơn.
Các ứng dụng từng sử dụng những chế độ cũ này với Dịch vụ HTML có thể cần phải thay đổi cho chế độ IFRAME
để giải quyết những điểm khác biệt sau:
- Giờ đây, bạn phải ghi đè thuộc tính
target
của đường liên kết bằng cách sử dụngtarget="_top"
hoặctarget="_blank"
- Các tệp HTML do Dịch vụ HTML phân phát phải bao gồm thẻ <!DOCTYPE html>, <html> và <body>
- Thư viện trình tải gốc của Google
api.js
không tự động tải ở chế độIFRAME
- Người dùng Picker cần gọi
setOrigin()
vì nội dung được phân phát từ một miền mới - Một số trình duyệt cũ, bao gồm cả IE9, không được hỗ trợ
- Giờ đây, các tài nguyên được nhập phải sử dụng HTTPS
- Theo mặc định, biểu mẫu sẽ không còn bị ngăn gửi nữa
Những điểm khác biệt này được trình bày chi tiết trong các phần sau.
Đặt thuộc tính mục tiêu liên kết
Ở chế độ IFRAME
, bạn cần đặt thuộc tính đích của đường liên kết thành _top
hoặc _blank
:
Code.js
function doGet() {
var template = HtmlService.createTemplateFromFile('top');
return template.evaluate();
}
top.html
<!DOCTYPE html>
<html>
<body>
<div>
<a href="http://google.com" target="_top">Click Me!</a>
</div>
</body>
</html>
Bạn cũng có thể ghi đè thuộc tính này bằng thẻ <base> trong phần đầu của trang web bao quanh:
<!DOCTYPE html>
<html>
<head>
<base target="_top">
</head>
<body>
<div>
<a href="http://google.com">Click Me!</a>
</div>
</body>
</html>
Thẻ HTML cấp cao nhất
Trong chế độ hộp cát NATIVE
(và EMULATED
), một số thẻ HTML sẽ tự động được thêm vào tệp .html của Apps Script, nhưng điều này không xảy ra khi sử dụng chế độ IFRAME
.
Để đảm bảo các trang dự án của bạn được phân phát chính xác bằng IFRAME
, hãy gói nội dung trang của bạn trong các thẻ cấp cao nhất sau:
<!DOCTYPE html>
<html>
<body>
<!-- Add your HTML content here -->
</body>
</html>
Bạn phải tải rõ ràng thư viện trình tải JavaScript gốc
Bạn phải thay đổi những tập lệnh dựa vào việc tự động tải thư viện trình tải gốc api.js
để tải thư viện này một cách rõ ràng, như trong ví dụ sau:
<script src="https://apis.google.com/js/api.js?onload=onApiLoad">
</script>
Thay đổi về Google Picker API
Khi sử dụng Google Picker API, giờ đây, bạn phải gọi setOrigin()
khi tạo PickerBuilder và truyền vào nguồn google.script.host.origin
, như minh hoạ trong ví dụ sau:
function createPicker(oauthToken) {
var picker = new google.picker.PickerBuilder()
.addView(google.picker.ViewId.SPREADSHEETS) // Or a different ViewId
.setOAuthToken(oauthToken)
.setDeveloperKey(developerKey)
.setCallback(pickerCallback)
.setOrigin(google.script.host.origin) // Note the setOrigin
.build();
picker.setVisible(true);
}
Để xem ví dụ đầy đủ về cách thức hoạt động, hãy xem phần Hộp thoại mở tệp.
Hỗ trợ trình duyệt
Chế độ hộp cát IFRAME
dựa trên tính năng hộp cát iframe trong HTML5.
Tính năng này không được hỗ trợ trong một số trình duyệt cũ, chẳng hạn như Internet Explorer 9. Đây có thể là một vấn đề nếu dự án Apps Script của bạn có cả hai trường hợp sau:
- sử dụng
HtmlService
và - hộp cát
EMULATED
hoặcNATIVE
đã dùng trước đây
Việc di chuyển các ứng dụng này sang chế độ hộp cát IFRAME
có nghĩa là các ứng dụng này có thể không còn hoạt động trên một số trình duyệt cũ (đặc biệt là IE9 trở về trước) không hỗ trợ tính năng hộp cát iframe của HTML5.
Những ứng dụng đã yêu cầu chế độ IFRAME
hoặc hoàn toàn không sử dụng HtmlService
sẽ không bị ảnh hưởng bởi vấn đề này.
Hiện tại, bạn phải sử dụng HTTPS cho các tài nguyên được nhập
Các ứng dụng trước đây nhập tài nguyên bằng HTTP phải được thay đổi để sử dụng HTTPS.
Theo mặc định, biểu mẫu sẽ không còn bị ngăn gửi nữa
Trong quá trình kiểm thử NATIVE
, các biểu mẫu HTML không được phép gửi và điều hướng trang. Do đó, nhà phát triển chỉ cần thêm một trình xử lý onclick
vào nút gửi mà không cần lo lắng về những gì xảy ra sau đó.
Tuy nhiên, với chế độ IFRAME
, các biểu mẫu HTML được phép gửi và nếu một phần tử biểu mẫu không có thuộc tính action
được chỉ định, thì phần tử đó sẽ gửi đến một trang trống.
Tệ hơn nữa, iframe bên trong sẽ chuyển hướng đến trang trống trước khi trình xử lý onclick
có cơ hội hoàn tất.
Giải pháp là thêm mã JavaScript vào trang để ngăn các phần tử biểu mẫu thực sự gửi, nhờ đó các trình xử lý lượt nhấp có thời gian hoạt động:
<script>
// Prevent forms from submitting.
function preventFormSubmit() {
var forms = document.querySelectorAll('form');
for (var i = 0; i < forms.length; i++) {
forms[i].addEventListener('submit', function(event) {
event.preventDefault();
});
}
}
window.addEventListener('load', preventFormSubmit);
</script>
Bạn có thể xem một ví dụ hoàn chỉnh trong hướng dẫn HtmlService Giao tiếp giữa máy khách và máy chủ.