Mô tả
Sử dụng API chrome.privacy
để kiểm soát việc sử dụng các tính năng trong Chrome có thể ảnh hưởng đến quyền riêng tư của người dùng. API này dựa vào nguyên mẫu ChromeSetting của loại API để lấy và đặt cấu hình của Chrome.
Quyền
privacy
Bạn phải khai báo quyền "quyền riêng tư" trong tệp kê khai của tiện ích để sử dụng API. Ví dụ:
{
"name": "My extension",
...
"permissions": [
"privacy"
],
...
}
Khái niệm và cách sử dụng
Việc đọc giá trị hiện tại của một chế độ cài đặt Chrome rất đơn giản. Trước tiên, bạn cần tìm tài sản mà bạn quan tâm, sau đó gọi get()
trên đối tượng đó để truy xuất giá trị hiện tại và cấp độ kiểm soát của tiện ích. Ví dụ: để xác định xem tính năng tự động điền thẻ tín dụng của Chrome có được bật hay không, bạn sẽ viết:
chrome.privacy.services.autofillCreditCardEnabled.get({}, function(details) {
if (details.value) {
console.log('Autofill is on!');
} else {
console.log('Autofill is off!');
}
});
Việc thay đổi giá trị của một chế độ cài đặt phức tạp hơn một chút, vì trước tiên, bạn phải xác minh rằng tiện ích của mình có thể kiểm soát chế độ cài đặt đó. Người dùng sẽ không thấy thay đổi nào đối với chế độ cài đặt của họ nếu tiện ích của bạn bật/tắt một chế độ cài đặt bị khoá ở một giá trị cụ thể theo chính sách doanh nghiệp (levelOfControl
sẽ được đặt thành "not_controllable") hoặc nếu một tiện ích khác đang kiểm soát giá trị đó (levelOfControl
sẽ được đặt thành "controlled_by_other_extensions"). Lệnh gọi set()
sẽ thành công, nhưng chế độ cài đặt sẽ bị ghi đè ngay lập tức. Vì điều này có thể gây nhầm lẫn, bạn nên cảnh báo người dùng khi chế độ cài đặt mà họ đã chọn không được áp dụng thực tế.
Điều này có nghĩa là bạn nên sử dụng phương thức get()
để xác định cấp truy cập, sau đó chỉ gọi set()
nếu tiện ích của bạn có thể kiểm soát chế độ cài đặt (thực tế nếu tiện ích của bạn không thể kiểm soát chế độ cài đặt, bạn nên tắt tính năng này để giảm sự nhầm lẫn của người dùng):
chrome.privacy.services.autofillCreditCardEnabled.get({}, function(details) {
if (details.levelOfControl === 'controllable_by_this_extension') {
chrome.privacy.services.autofillCreditCardEnabled.set({ value: true }, function() {
if (chrome.runtime.lastError === undefined) {
console.log("Hooray, it worked!");
} else {
console.log("Sadness!", chrome.runtime.lastError);
}
});
}
});
Nếu bạn quan tâm đến các thay đổi đối với giá trị của một chế độ cài đặt, hãy thêm trình nghe vào sự kiện onChange
của chế độ cài đặt đó. Ngoài các mục đích sử dụng khác, tính năng này cho phép bạn cảnh báo người dùng nếu một tiện ích được cài đặt gần đây hơn giành quyền kiểm soát một chế độ cài đặt hoặc nếu chính sách doanh nghiệp ghi đè quyền kiểm soát của bạn. Ví dụ: để theo dõi các thay đổi về trạng thái tự động điền thẻ tín dụng, bạn chỉ cần mã sau:
chrome.privacy.services.autofillCreditCardEnabled.onChange.addListener(
function (details) {
// The new value is stored in `details.value`, the new level of control
// in `details.levelOfControl`, and `details.incognitoSpecific` will be
// `true` if the value is specific to Incognito mode.
}
);
Ví dụ
Để dùng thử API này, hãy cài đặt ví dụ về API quyền riêng tư từ kho lưu trữ chrome-extension-samples.
Loại
IPHandlingPolicy
Chính sách xử lý IP của WebRTC.
Enum
"mặc định"
"default_public_and_private_interfaces"
"default_public_interface_only"
"disable_non_proxied_udp"
Thuộc tính
network
Các chế độ cài đặt ảnh hưởng chung đến cách Chrome xử lý các kết nối mạng.
Loại
đối tượng
Thuộc tính
-
networkPredictionEnabled
types.ChromeSetting<boolean>
Nếu được bật, Chrome sẽ cố gắng tăng tốc trải nghiệm duyệt web của bạn bằng cách phân giải trước các mục nhập DNS và mở trước các kết nối TCP và SSL đến máy chủ. Lựa chọn ưu tiên này chỉ ảnh hưởng đến các hành động do dịch vụ dự đoán nội bộ của Chrome thực hiện. Điều này không ảnh hưởng đến các hoạt động tải trước hoặc kết nối trước do trang web khởi tạo. Giá trị của tuỳ chọn này là boolean, mặc định là
true
. -
webRTCIPHandlingPolicyChrome 48 trở lên
Cho phép người dùng chỉ định sự đánh đổi giữa hiệu suất nội dung nghe nhìn/quyền riêng tư. Điều này ảnh hưởng đến cách định tuyến lưu lượng truy cập WebRTC và lượng thông tin địa chỉ cục bộ được tiết lộ. Giá trị của tuỳ chọn này thuộc loại IPHandlingPolicy, mặc định là
default
.
services
Các chế độ cài đặt bật hoặc tắt các tính năng yêu cầu dịch vụ mạng của bên thứ ba do Google và nhà cung cấp dịch vụ tìm kiếm mặc định của bạn cung cấp.
Loại
đối tượng
Thuộc tính
-
alternateErrorPagesEnabled
types.ChromeSetting<boolean>
Nếu bạn bật, Chrome sẽ sử dụng một dịch vụ web để giúp giải quyết lỗi điều hướng. Giá trị của tuỳ chọn này là một boolean, mặc định là
true
. -
autofillAddressEnabled
types.ChromeSetting<boolean>
Chrome 70 trở lênNếu bạn bật tính năng này, Chrome sẽ tự động điền địa chỉ và các dữ liệu khác trên biểu mẫu. Giá trị của tuỳ chọn này là một boolean, mặc định là
true
. -
autofillCreditCardEnabled
types.ChromeSetting<boolean>
Chrome 70 trở lênNếu bạn bật tính năng này, Chrome sẽ tự động điền vào biểu mẫu thẻ tín dụng. Giá trị của tuỳ chọn này là boolean, mặc định là
true
. -
autofillEnabled
types.ChromeSetting<boolean>
Ngừng sử dụng kể từ Chrome 70Vui lòng sử dụng privacy.services.autofillAddressEnabled và privacy.services.autofillCreditCardEnabled. Tính năng này vẫn được giữ lại để đảm bảo khả năng tương thích ngược trong bản phát hành này và sẽ bị xoá trong tương lai.
Nếu bạn bật tính năng này, Chrome sẽ tự động điền thông tin vào biểu mẫu. Giá trị của tuỳ chọn này là một boolean, mặc định là
true
. -
passwordSavingEnabled
types.ChromeSetting<boolean>
Nếu bạn bật, trình quản lý mật khẩu sẽ hỏi xem bạn có muốn lưu mật khẩu hay không. Giá trị của tuỳ chọn này là một boolean, mặc định là
true
. -
safeBrowsingEnabled
types.ChromeSetting<boolean>
Nếu bạn bật chế độ này, Chrome sẽ nỗ lực hết sức để bảo vệ bạn khỏi hành vi lừa đảo và phần mềm độc hại. Giá trị của tuỳ chọn này là boolean, mặc định là
true
. -
safeBrowsingExtendedReportingEnabled
types.ChromeSetting<boolean>
Nếu bạn bật tính năng này, Chrome sẽ gửi thêm thông tin cho Google khi tính năng Duyệt web an toàn chặn một trang, chẳng hạn như nội dung của trang bị chặn. Giá trị của tuỳ chọn này là một boolean, mặc định là
false
. -
searchSuggestEnabled
types.ChromeSetting<boolean>
Nếu bạn bật tính năng này, Chrome sẽ gửi văn bản bạn nhập vào Thanh địa chỉ đến công cụ tìm kiếm mặc định. Công cụ này sẽ cung cấp nội dung gợi ý về các trang web và nội dung tìm kiếm có thể là nội dung hoàn chỉnh của những gì bạn đã nhập cho đến thời điểm đó. Giá trị của tuỳ chọn này là boolean, mặc định là
true
. -
spellingServiceEnabled
types.ChromeSetting<boolean>
Nếu bạn bật, Chrome sẽ sử dụng một dịch vụ web để giúp sửa lỗi chính tả. Giá trị của tuỳ chọn này là boolean, mặc định là
false
. -
translationServiceEnabled
types.ChromeSetting<boolean>
Nếu bạn bật tính năng này, Chrome sẽ đề xuất dịch các trang không phải bằng ngôn ngữ bạn đọc. Giá trị của tuỳ chọn này là boolean, mặc định là
true
.
websites
Các chế độ cài đặt xác định thông tin mà Chrome cung cấp cho các trang web.
Loại
đối tượng
Thuộc tính
-
adMeasurementEnabled
types.ChromeSetting<boolean>
Chrome 111 trở lênNếu bạn tắt, Attribution Reporting API và Private Aggregation API sẽ bị vô hiệu hoá. Giá trị của tuỳ chọn này thuộc loại boolean và giá trị mặc định là
true
. Tiện ích chỉ có thể tắt các API này bằng cách đặt giá trị thànhfalse
. Nếu bạn cố gắng đặt các API này thànhtrue
, thì sẽ xảy ra lỗi. -
doNotTrackEnabled
types.ChromeSetting<boolean>
Chrome 65 trở lênNếu bạn bật, Chrome sẽ gửi tiêu đề "Do Not Track" (
DNT: 1
) (Không theo dõi) cùng với các yêu cầu của bạn. Giá trị của tuỳ chọn này thuộc loại boolean và giá trị mặc định làfalse
. -
fledgeEnabled
types.ChromeSetting<boolean>
Chrome 111 trở lênNếu bị tắt, Fledge API sẽ bị huỷ kích hoạt. Giá trị của tuỳ chọn này thuộc loại boolean và giá trị mặc định là
true
. Tiện ích chỉ có thể tắt API này bằng cách đặt giá trị thànhfalse
. Nếu bạn cố gắng đặt API này thànhtrue
, API sẽ gửi ra lỗi. -
hyperlinkAuditingEnabled
types.ChromeSetting<boolean>
Nếu được bật, Chrome sẽ gửi ping kiểm tra khi trang web yêu cầu (
<a ping>
). Giá trị của tuỳ chọn ưu tiên này thuộc loại boolean và giá trị mặc định làtrue
. -
protectedContentEnabled
types.ChromeSetting<boolean>
Chỉ có trên Windows và ChromeOS: Nếu được bật, Chrome sẽ cung cấp mã nhận dạng duy nhất cho các trình bổ trợ để chạy nội dung được bảo vệ. Giá trị của tuỳ chọn này thuộc loại boolean và giá trị mặc định là
true
. -
referrersEnabled
types.ChromeSetting<boolean>
Nếu được bật, Chrome sẽ gửi các tiêu đề
referer
cùng với các yêu cầu của bạn. Có, tên của tuỳ chọn này không khớp với tiêu đề bị sai chính tả. Không, chúng tôi sẽ không thay đổi điều đó. Giá trị của tuỳ chọn này thuộc loại boolean và giá trị mặc định làtrue
. -
types.ChromeSetting<boolean>
Chrome 121 trở lênNếu bạn tắt tính năng này, Bộ trang web có liên quan sẽ bị huỷ kích hoạt. Giá trị của tuỳ chọn này thuộc loại boolean và giá trị mặc định là
true
. Tiện ích chỉ có thể tắt API này bằng cách đặt giá trị thànhfalse
. Nếu bạn cố gắng đặt API này thànhtrue
, API sẽ gửi ra lỗi. -
thirdPartyCookiesAllowed
types.ChromeSetting<boolean>
Nếu bạn tắt chế độ này, Chrome sẽ chặn các trang web bên thứ ba đặt cookie. Giá trị của tuỳ chọn này thuộc loại boolean và giá trị mặc định là
true
.**Lưu ý:**Các trang web riêng lẻ vẫn có thể truy cập vào cookie của bên thứ ba khi API này trả về
false
, nếu các trang web đó có miễn trừ hợp lệ hoặc sử dụng Storage Access API. -
topicsEnabled
types.ChromeSetting<boolean>
Chrome 111 trở lênNếu bị tắt, Topics API sẽ bị vô hiệu hoá. Giá trị của tuỳ chọn này thuộc loại boolean và giá trị mặc định là
true
. Tiện ích chỉ có thể tắt API này bằng cách đặt giá trị thànhfalse
. Nếu bạn cố gắng đặt API này thànhtrue
, API sẽ gửi ra lỗi.