Services
These services are available in the Pre-Production and Production systems.
Base URLs for the two systems are:
Environment | URL |
---|---|
Pre-Production | https://services-preprod.bankid.no |
Production | https://services.bankid.no |
Test your BankID
The test tool is meant to be embedded in a merchant's website, for instance in an iframe.
Applicable to the Java applet only: To match the rest of the site, the font and size of the text used outside the applet can be specified to match the rest of the site.
Access URLs
| Function | URL |
---|---|---|
Mobile | Test your Mobile BankID | <baseURL>/test/test?type=mobil&action=authAndSign |
Show your Mobile BankID certificate | <baseURL>/test/test?type=mobil&action=showCert | |
Web-client | Test your BankID Web-client | <baseURL>/test/test?type=webclient&action=authAndSign |
Auth | <baseURL>/test/test?type=webclient&action=auth | |
Sign * | <baseURL>/test/test?type=webclient&action=sign | |
Sign xml * | <baseURL>/test/test?type=webclient&action=signXml | |
Sign Pdf * | <baseURL>/test/test?type=webclient&action=signPdf | |
Sign multi docs | <baseURL>/test/test?type=webclient&action=multisign&clientVersion=2.1 | |
Netpay | <baseURL>/test/test?type=webclient&action=netpay | |
Changepassword | <baseURL>/test/test?type=webclient&action=changepassword |
*Note that the Sign operations (Sign, Sign xml, Sign Pdf) for the Web-client listed above may be called both with and without the &clientVersion=2.1 parameter, i.e.
<baseURL>/test/test?type=webclient&action=sign&clientVersion=2.1
<baseURL>/test/test?type=webclient&action=sign&clientVersion=2.0
<baseURL>/test/test?type=webclient&action=sign
This will determine which BankID version to use for the signing operations. By omitting the clientVersion part the default version (2.0) will be used. Further note that the multisign URL only works for 2.1 as shown in the above table.
<baseURL>/test/test?type=webclient&action=sign&clientVersion=2.0
is also valid.
The following parameters may be added to specify font and font-size, and are only applicable for the Java applet:
Function | URL |
---|---|
Font | font=<font-name[,font-name]...> |
Font-size | size=<size> |
Example
https://services.bankid.no/test/test?type=webclient&action=authAndSign&clientVersion=2.0
Transaction Counter
Access URLs
Function | URL |
---|---|
Transactions pr. second netcentric | <baseURL>/bankid/netcentric/counter/transactionsprsecond/ |
Transactions today netcentric | <baseURL>/bankid/netcentric/counter/transactionstoday/ |
Transactions pr. second mobile | <baseURL>/bankid/mobile/counter/transactionsprsecond/ |
Transactions today mobile | <baseURL>/bankid/mobile/counter/transactionstoday/ |
CheckMobile
This service lets a user check whether a given mobile number/mobile phone can be used with Mobile BankID.
Access URL
Function | URL |
---|---|
Check mobile | <baseURL>/bankid/checkmobile |
Parameters are given in the query part of the URL.
Parameters
Parameter | Required | Description |
---|---|---|
msisdn | Yes | Mobile number to check |
Example
Checking a number
Check if number 99889988 can be used:
Results
The service returns the status code from the MNO. The following codes are defined:
Status code | Description |
---|---|
OK | Mobile phone and subscription are enabled for Mobile BankID |
NOT_ACTIVE | Subscription is not known to Mobile Network Operator (MNO) |
INVALID_SIM | Subscriber Identidy Module (SIM) card must be replaced by MNO in order to get Mobile BankID. |
INVALID_SUBSCRIPTION | The mobile subscription does not support Mobile BankID. |
ERROR_IN_SUBSCRIPTION | There may be an error in the MNO subscription system. This may be solved within 24 hours. If the problem persists, contact MNO support. |
INVALID_PHONE | Phone is not enabled for Mobile BankID. |
MNO_DOES_NOT_SUPPORT_BANKID_MOBILE | The MNO of the Mobile Station International Subscriber Directory Number (MSISDN) does not support Mobile BankID. |
MSISDN_DOES_NOT_EXIST | MSISDN does not exist in the National Resources DataBase (NRDB). |
SIM_MISSING_PKI_SUPPORT | The end user's SIM card does not support Public Key Infrastructure (PKI)/BankID. An automatic update is issued by the MNO, this involves a restart of the user's mobile phone. The end user has to be informed in the net bank web page. |
SIM_REACHED_MAX_ACTIVATIONS | The end user's SIM card cannot be activated again, the user must get a new SIM card from the MNO. For Telenor, this occurs at the 85th activation. |
ASYNC_PROCESSING | The request is processed asynchronously. |
ERROR | An unspecified error occurred in the infrastructure. This code is returned if the request could not be processed. |
BankID Counter
This service gives the number of active certificates or unique users. Note that the values are cached for a certain (configurable) time, so new certificates are not immediately visible.
Access URLs
Function | URL |
---|---|
Netcentric PersonBankIDs | <baseURL>/bankid/netcentric/counter/certificates/person |
Netcentric EmployeeBankIDs | <baseURL>/bankid/netcentric/counter/certificates/employee |
Mobile BankIDs | <baseURL>/bankid/mobile/counter/certificates |
Number of unique users | <baseURL>/bankid/counter/unique |
Unique users with netcentric certificates | <baseURL>/bankid/netcentric/counter/unique |
Unique users with mobile certificates | <baseURL>/bankid/mobile/counter/unique |
Feature detection and UA detection script
verifyBrowser
The entry point of the API is the method called verifyBrowser. The simplest possible use of this method could look like this:
bidBrowserTest.verifyBrowser({ onNoSupport: function () { console.log("Your browser does NOT support the BankID Web-client! :C "); } });
This call invokes the asynchronous feature detection process, which has three possible outcomes, each of which is associated with a callback:
Callback | Explanation |
---|---|
onFullSupport | All features are supported, and the BankID Web-client will function. |
onNoSupport | One or more required features are not supported, and the BankID Web-client will not function. Example: Cross-origin resource sharing (CORS) is not supported. |
onLimitedSupport | The BankID Web-client will function, but one or more recommended features are not supported. Example: Cookies are disabled. Example: Content security policy (CSP) is not honoured/understood by the browser. |
result-object
Each callback gets sent a result-object as argument. This may optionally be used to retrieve further details about what went wrong if needed.
result may look like this:
var result = { code: 41, message: "Cookies are disabled", action: "Enable cookies", details: […] };
result is the conclusion as to what went wrong, or possibly that everything is ok and that the BankID Web-client will function properly in the user's browser. Each result is tied to a static (error) code which in turn may be used by the merchant to show customised texts and graphics instead of the default texts provided in the message- and action-fields. The language used in these texts is Norwegian bokmål unless otherwise specified through the use of withLocale.
The result-object:
Field | Type | Explanation | Example |
---|---|---|---|
code | number (JS:number) | Static (error) code in order to show custom texts. An overview of the (error) codes and their meaning can be found further down on this page. | 41 (cookies are disabled) |
message | text (JS:string) | Contains a default text that describes the test result. | "Cookies are enabled" |
action | text (JS:string) | Contains a default text that recommends an action the user could take. This field is absent in case the test is "green" or otherwise no recommendation exists, such as if everything went ok. | "Enable cookies" |
details | list (JS:object[]) | An array of detailed test results, one for each feature being tested. See below for further explanation of the details-field. | [ { … }, { … } ] |
result also contains the field details, a list of detailed test results, one for each feature that was tested. The data structure for each such element in the list is similar to that of result (without the details-field), but contains an additional field supportLevel that defines to which degree the browser supports the feature. The field is an enumeration over the values "noSupport", "limitedSupport", and "fullSupport".
details can look like this:
result.details = [ { code: 10, message: "CORS is supported", supportLevel: "fullSupport" }, { code: 21, message: "XDM is not supported", action: "Upgrade your browser", supportLevel: "noSupport" }, { code: 41, message: "Cookies are disabled", action: "Enable cookies", supportLevel: "limitedSupport" } ];
Note that, based on severity, a test result with a supportLevel different from "fullSupport" becomes the conclusion and top result passed to the callback.
The details-object:
Field | Type | Explanation | Example |
---|---|---|---|
code, message, and action are the same as above. | |||
supportLevel | enumeration (JS:string) | Defines to which degree a particular feature is supported by the browser. Example: If CORS is supported, then supportLevel becomes "fullSupport". Example: If XDM is not supported, then supportLevel becomes "noSupport". Example: If cookies are disabled, then supportLevel becomes "limitedSupport". [1] [1] Recommended features such as cookies and CSP will never have a test result with a supportLevel of "noSupport", only "limitedSupport". | One of: "fullSupport" |
Extended example of the use of result and details:
bidBrowserTest.verifyBrowser({ onFullSupport: function () { console.log("Your browser fully supports the BankID Web-client!"); }, onNoSupport: function(result) { console.error("Your browser does NOT support the BankID Web-client!"); console.error("Error code: " + result.code); console.error("What went wrong: " + result.message); console.error("What you can do: " + result.action); console.error("The following features were tested:"); result.details.forEach(function (detail) { console.error(" Feature:"); console.error(" Result code: " + detail.code); console.error(" Message: " + detail.message); console.error(" Action: " + detail.action); console.error(" Level of support: " + detail.supportLevel); }); } });
The result-object sent to onFullSupport, onLimitedSupport, and onNoSupport are identical, so creating a common method that handles all three callbacks may be advantageous, such as to present the results to the user.
Example:
bidBrowserTest.verifyBrowser({ onFullSupport: showResult, onLimitedSupport: showResult, onNoSupport: showResult }); function showResult(result) { // Show the test result and/or list detailed test results contained in result.details. }
There is also a callback onError that may be specified to handle unexpected errors that occur during testing. Should onError not be defined the exception will be raised from within the asynchronous process and will only become visible in the console. Note that once verifyBrowser has been called it immediately returns after having started the asynchronous process, which also means that no errors will be thrown from it. Use the callback instead.
Example:
bidBrowserTest.verifyBrowser({ onError: function (e) { console.error("Error while running tests: " + e); } });
(Note that during testing, nothing could be found that would cause such an unexpected exception to be raised. It is however recommended to handle onError in case an error occurs in the future.)
Result codes
The following table comprises the complete list of result codes and by that also the complete list of features tested for.
code | Meaning | supportLevel | Message (localised) | Action (localised) |
---|---|---|---|---|
0 | Everything ok. The browser fully supports the BankID Web-client. | fullSupport | Your browser will work properly | Your browser will work properly |
100 | All required features are supported.
To show a more technical classification of the result set, set friendly to false in the call to verifyBrowser. | fullSupport | Required features are supported by your browser | None |
101 | Required features are not supported. One or more features in the list above are not supported. To show a more technical classification of the result set, set friendly to false in the call to verifyBrowser. | noSupport | Required features are not supported by your browser | You must upgrade your browser for it to work properly. |
102 | Required features are only partially supported. Cross-origin resource sharing (CORS) is only partially supported through XDomainRequest (IE 8/9). To show a more technical classification of the result set, set friendly tofalse in the call to verifyBrowser. | limitedSupport | Required features are only partially supported by your browser | Your browser will work, but not optimally. We recommend upgrading your browser for a better user experience. |
110 | Cross-origin resource sharing (CORS) is supported. | fullSupport | CORS is supported | None |
111 | Cross-origin resource sharing (CORS) is not supported. | noSupport | CORS is not supported | You must upgrade your browser for it to work properly. |
112 | Cross-origin resource sharing (CORS) is only partially supported through XDomainRequest (IE 8/9). | limitedSupport | CORS is only partially supported | Your browser will work, but not optimally. We recommend upgrading your browser for a better user experience. |
120 | Cross-document messaging (XDM) is supported. | fullSupport | XDM is supported | None |
121 | Cross-document messaging (XDM) is not supported. | noSupport | XDM is not supported | You must upgrade your browser for it to work properly. |
130 | The browser is not blacklisted. | fullSupport | Browser is accepted | None |
131 | The browser is blacklisted and blocked. For details regarding which UA-strings are being actively blacklisted, contact BankID. | noSupport | Browser is blocked | You must upgrade your browser for it to work properly. |
200 | All recommended features are supported.
To show a more technical classification of the result set, set friendly tofalse in the call to verifyBrowser. [1] Note that unless extended is set to true in the call to verifyBrowser, no feature detection is run against these features. See section 3.5.4 for more information. | fullSupport | Recommended features are supported by your browser | None |
201 | Recommended features are not supported. One or more features in the list above are not supported. To show a more technical classification of the result set, set friendly to false in the call to verifyBrowser. | limitedSupport | Recommended features are not supported by your browser | Your browser will work, but not optimally. We recommend upgrading your browser for a better user experience. |
210 | Cookies are enabled and available. | fullSupport | Cookies are enabled | None |
211 | Cookies are disabled or otherwise unavailable. | limitedSupport | Cookies are disabled | Your browser will work, but not optimally. We recommend enabling cookies. |
220 | Content security policy (CSP) is supported. | fullSupport | CSP is supported | None |
221 | Content security policy (CSP) is not supported. Warning! If you are using the JavaScript API to invoke verifyBrowser with extended See section 3.5.4 for more information on use of the extended flag.set to true, it is vital that CSP has been activated by you, the merchant, by setting the Content-Security-Policy-header in the http-response for the page that loads bid-browser-test.js. This must be done for any page that uses the JavaScript API. Remember to send the corresponding header for the given browser as the particular name of the CSP header varies from browser to browser. Example:
It is important not to work around inline code evaluation by specifying inline-eval in the source list for default-src or script-src since this is what is being used for feature detection of CSP. If these precautions are not taken, the test will simply report false positives that CSP is not supported. Example (don't do this!): Also note that no version of Internet Explorer currently (IE 11) supports CSP in compliance with the W3C-specification. | limitedSupport | CSP is not supported | Your browser will work, but not optimally. We recommend upgrading your browser for a better user experience. |
230 | Canvas is supported. | fullSupport | HTML5 Canvas is supported | None |
231 | Canvas is not supported. | limitedSupport | HTML5 Canvas is not supported | Your browser will work, but not optimally. We recommend upgrading your browser for a better user experience. |
240 | Scalable vector graphics (SVG) is supported. | fullSupport | HTML5 SVG is supported | None |
241 | Scalable vector graphics (SVG) is not supported. | noSupport | HTML5 SVG is not supported | You must upgrade your browser for it to work properly. |
250 | Object.keys is supported. | fullSupport | Object.keys is supported | None |
251 | Object.keys is not supported. | noSupport | Object.keys is not supported | You must upgrade your browser for it to work properly. |
260 | Selectors API is supported. | fullSupport | Query selectors are supported | None |
261 | Selectors API is not supported. | noSupport | Query selectors are not supported | You must upgrade your browser for it to work properly. |
270 | JSON is supported. | fullSupport | JSON is supported | None |
271 | JSON is not supported. | noSupport | JSON is not supported | You must upgrade your browser for it to work properly. |
280 | Element.outerHTML is supported. | fullSupport | Element.outerHTML is supported | None |
281 | Element.outerHTML is not supported. | noSupport | Element.outerHTML is not supported | You must upgrade your browser for it to work properly. |
290 | Web Cryptography API1 | fullSupport | Web Cryptography is supported | None |
291 | Web Cryptography API1 | limitedSupport | Web Cryptography is not supported | Your browser will work, but not optimally. We recommend upgrading your browser for a better user experience. |
310 | Web Storage API is supported. | fullSupport | Web Storage is supported | None |
311 | Web Storage API is not supported. | limitedSupport | Web Storage is not supported | Your browser will work, but not optimally. We recommend upgrading your browser for a better user experience. |
320 | Geolocation API is supported. | fullSupport | Geolocation is supported | None |
321 | Geolocation API is not supported. | limitedSupport | Geolocation is not supported | Your browser will work, but not optimally. We recommend upgrading your browser for a better user experience. |
330 | Web Graphics Library (WebGL)1 is supported. | fullSupport | WebGL is supported | None |
331 | Web Graphics Library (WebGL)1 is not supported. | limitedSupport | WebGL is not supported | Your browser will work, but not optimally. We recommend upgrading your browser for a better user experience. |
340 | Web Real-Time Communication API (WebRTC)1 is supported. | fullSupport | WebRTC is supported | None |
341 | Web Real-Time Communication API (WebRTC)1 is not supported. |
| WebRTC is not supported | Your browser will work, but not optimally. We recommend upgrading your browser for a better user experience. |
350 | ShadowDOM API1 is supported. | fullSupport | ShadowDOM is supported. | None |
351 | ShadowDOM API1 is not supported. | limitedSupport | ShadowDOM is not supported. | Your browser will work, but not optimally. We recommend upgrading your browser for a better user experience. |
360 | MuationObserver API is supported. | fullSupport | MuationObserver is supported. | None |
361 | MutationObserver API is not supported. | limitedSupport | MutationObserver is not supported. | Your browser will work, but not optimally. We recommend upgrading your browser for a better user experience. |
1 See section 3.5.4 for more information on use of the extended flag. is supported.
Extended and friendly results
The verifyBrowser-method provides the ability to hide technical details in the result set and to run an extended feature detection by setting the friendly and extended flags, respectively. The flags may be specified in the attributes map sent to verifyBrowser in the same manner as the callbacks. Defaults are true for friendly, and false for extended.
Example:
bidBrowserTest.verifyBrowser({ friendly: false, // Show me everything. extended: true, // Run all tests, including CSP. onFullSupport: function () { : } });
Note that the following recommended features are not yet widely supported and because of this they are disabled by default in the test. Testing for these features is enabled by setting the extended-parameter true, as shown in the example above.
- Content Security Policy (CSP)
- Web Cryptography API
- Web Graphics Library (WebGL)
- Web Real-Time Communication API (WebRTC)
- ShadowDOM
Since no version of Internet Explorer currently (IE 11) supports CSP it is cautioned against running extended tests due to the fact that this will result in a negative result for all users of IE. This is way the CSP-test is disabled by default.
Localization
withLocale lets you specify the desired language to be used in the test results coming from verifyBrowser, particularly result.message and result.action. The method returns the framework itself, so that it may be used with chaining.
Example:
bidBrowserTest.withLocale("en").verifyBrowser();
Currently, only Norwegian bokmål (nb) and English (en) are supported.
Test your browser
It is possible to test your browser by running the Feature- and UA detection script using services-test. The link to the test can be found in the table below.
The test site loads the script in two ways. The first way loads the script using <script src=".."> in the html document, and the second way loads the script using requirejs. By setting extended and friendly to true or false, different sets of tests are run.
Function | URL |
---|---|
Test your browser |
|
BaseURL is defined in section 3.
Security Data
As described in section 2. See the document [ISDS] (restricted) for more information.