How to tackle issues in accessing embedded Smarten objects through API in the latest version of Chrome (chrome 84.0.4147)?
Posted about 4 years ago by Smarten - Solution Team
Post a topicPeople who like this
Delete Comment
This post will be deleted permanently. Are you sure?
Code Snippet
Html
Html
Css
JavaScript
Sass
Xml
Ruby
PHP
Java
C#
C++
ObjectiveC
Perl
Python
VB
SQL
Generic Language
Issue / Query:
While opening embedded Smarten objects through API in our web application in the latest version of chrome (chrome 84.0.4147), it is showing the error as shown in the below screenshot.
This had been working fine up until the browser was upgraded to the latest version (chrome 84.0.4147).
0 Votes
Smarten - Solution Team posted about 4 years ago Admin Best Answer
Issue / Query:
While opening embedded Smarten objects through API in our web application in the latest version of chrome (chrome 84.0.4147), it is showing the error as shown in the below screenshot.
This had been working fine up until the browser was upgraded to the latest version (chrome 84.0.4147).
Reason:
This is purely a CORS (Cross-Origin Resource Sharing) error that happens when Smarten is hosted at a different IP than your website or web application. The latest version of chrome(chrome 84.0.4147) blocks the same.
The CORS mechanism supports secure cross-origin requests and data transfers between browsers and servers. But CORS is subject to change in Chrome version as in the latest version, the web security roles have been changed as part of security and those must handled properly.
Solution:
Proper IP tunneling should be done to make this work. This has to be done differently for the applications developed in PHP, .Net, etc.
1. Application in PHP / Java
Apache web server need to be installed in the host for handling this for the sites developed in PHP / Java. After this, proxy pass setting through apache should be done. The below mentioned code has to be added in your ‘VirtualHost’ file for the same.
<VirtualHost *:80>
ServerNamelocalhost
ProxyPreserveHost On
ProxyPass /smarten http://localhost:8080/smarten(Mention Smarten URL here)
ProxyPassReverse /smarten http://locahost:8080/smarten (Mention Smarten URL here)
RewriteEngine On
ErrorLog ${APACHE_LOG_DIR}/error.log
CustomLog ${APACHE_LOG_DIR}/access.log combined
</VirtualHost>
2. Application in .Net or hosted IIS web server
If the application is developed in .Net or they are hosted in IIS web server, a connector extension (AJP13) need to be installed to handle this situation.
a. Download the latest version of AJP13 from https://github.com/Bilal-S/iis2tomcat/releases/tag/1.0.42
b. Extract the .zip-file to a temp folder (AJP13_v1042.zip)
EXTRACTED FILES
c. Run “dotnetfx35setup.exe” if .NET 3.5 has not been installed on the server.
d. Execute “Connector_Setup.exe”.
SERVER AND PORT DETAILS
GLOBAL OR SPECIFIC SITE OPTION
ENVIRONMENT CONFIGURATION
FINAL STEP OF INSTALLER
e. The installer copies all the binaries and configuration files to “c:\\Windows”.
f. After this, modify the content of “BonCodeAJP13.settings” as below.
<Settings>
<Port>8009</Port>
<Server>localhost</Server>
<MaxConnections>200</MaxConnections>
<LogLevel>1</LogLevel>
<FlushThreshold>0</FlushThreshold>
<EnableRemoteAdmin>False</EnableRemoteAdmin>
<LogDir>E:\LogFiles\APPLogs\BoncodeAJP</LogDir>
<EnableHTTPStatusCodes>True</EnableHTTPStatusCodes>
</Settings>
Note: Make sure the IIS Application Pool user has access rights to ‘LogDir’ folder.
g. A folder named “bin” will be created in the root of your website. Copy the below two files to the bin folder.
h. After this, specify the folders that have to be forwarded to the wildfly. For Smarten, create a new folder in the root of the website named “smarten”.
i. Copy the “bin” folder under “smarten” folder.
j. Add handler mapping in IIS after this. Go to the subfolder named “smarten” and add a new managed handler as below.
HANDLER MAPPINGS
k. Specify the request path as “*”, Select type as “BonCodeIIS…” and Name as “BonCodeAll”.
MANAGED HANDLER SETTINGS
l. Open the standalone.xml configuration file, and add the below mentioned parameter under the http-listener parameter.
<ajp-listener name="ajp" socket-binding="ajp"/>
m. Reset IIS after this. Run “iisreset” to reload the setting file.
After making the above changes as per the application hosting options, whenever the host sends a request to Apache (where Smarten is hosted), proxy passes the request to the tunnel and then request will be handled. Host IP and Smarten IP will be considered as the same, and this issue will not occur.
0 Votes
1 Comments
Smarten - Solution Team posted about 4 years ago Admin Answer
Issue / Query:
While opening embedded Smarten objects through API in our web application in the latest version of chrome (chrome 84.0.4147), it is showing the error as shown in the below screenshot.
This had been working fine up until the browser was upgraded to the latest version (chrome 84.0.4147).
Reason:
This is purely a CORS (Cross-Origin Resource Sharing) error that happens when Smarten is hosted at a different IP than your website or web application. The latest version of chrome(chrome 84.0.4147) blocks the same.
The CORS mechanism supports secure cross-origin requests and data transfers between browsers and servers. But CORS is subject to change in Chrome version as in the latest version, the web security roles have been changed as part of security and those must handled properly.
Solution:
Proper IP tunneling should be done to make this work. This has to be done differently for the applications developed in PHP, .Net, etc.
1. Application in PHP / Java
Apache web server need to be installed in the host for handling this for the sites developed in PHP / Java. After this, proxy pass setting through apache should be done. The below mentioned code has to be added in your ‘VirtualHost’ file for the same.
<VirtualHost *:80>
ServerNamelocalhost
ProxyPreserveHost On
ProxyPass /smarten http://localhost:8080/smarten(Mention Smarten URL here)
ProxyPassReverse /smarten http://locahost:8080/smarten (Mention Smarten URL here)
RewriteEngine On
ErrorLog ${APACHE_LOG_DIR}/error.log
CustomLog ${APACHE_LOG_DIR}/access.log combined
</VirtualHost>
2. Application in .Net or hosted IIS web server
If the application is developed in .Net or they are hosted in IIS web server, a connector extension (AJP13) need to be installed to handle this situation.
a. Download the latest version of AJP13 from https://github.com/Bilal-S/iis2tomcat/releases/tag/1.0.42
b. Extract the .zip-file to a temp folder (AJP13_v1042.zip)
EXTRACTED FILES
c. Run “dotnetfx35setup.exe” if .NET 3.5 has not been installed on the server.
d. Execute “Connector_Setup.exe”.
SERVER AND PORT DETAILS
GLOBAL OR SPECIFIC SITE OPTION
ENVIRONMENT CONFIGURATION
FINAL STEP OF INSTALLER
e. The installer copies all the binaries and configuration files to “c:\\Windows”.
f. After this, modify the content of “BonCodeAJP13.settings” as below.
<Settings>
<Port>8009</Port>
<Server>localhost</Server>
<MaxConnections>200</MaxConnections>
<LogLevel>1</LogLevel>
<FlushThreshold>0</FlushThreshold>
<EnableRemoteAdmin>False</EnableRemoteAdmin>
<LogDir>E:\LogFiles\APPLogs\BoncodeAJP</LogDir>
<EnableHTTPStatusCodes>True</EnableHTTPStatusCodes>
</Settings>
Note: Make sure the IIS Application Pool user has access rights to ‘LogDir’ folder.
g. A folder named “bin” will be created in the root of your website. Copy the below two files to the bin folder.
h. After this, specify the folders that have to be forwarded to the wildfly. For Smarten, create a new folder in the root of the website named “smarten”.
i. Copy the “bin” folder under “smarten” folder.
j. Add handler mapping in IIS after this. Go to the subfolder named “smarten” and add a new managed handler as below.
HANDLER MAPPINGS
k. Specify the request path as “*”, Select type as “BonCodeIIS…” and Name as “BonCodeAll”.
MANAGED HANDLER SETTINGS
l. Open the standalone.xml configuration file, and add the below mentioned parameter under the http-listener parameter.
<ajp-listener name="ajp" socket-binding="ajp"/>
m. Reset IIS after this. Run “iisreset” to reload the setting file.
After making the above changes as per the application hosting options, whenever the host sends a request to Apache (where Smarten is hosted), proxy passes the request to the tunnel and then request will be handled. Host IP and Smarten IP will be considered as the same, and this issue will not occur.
0 Votes
Login or Sign up to post a comment