File Upload and Download

Appeon PowerServer provides a non-visual object, AppeonFileService object, with five functions for uploading files to and downloading files from the file server. This is a web-based solution, and it does not work in your client/server application.

You should follow the steps below to implement File Upload and Download:

Step 1: Configuring and deploying the file server

Step 2: Uploading and Downloading files

Configuring and deploying Appeon File Server

Appeon File Server is a standard non-visual Web application running on the back-end for uploading and downloading files. For PowerServer installed to the .NET IIS, the setup wizard of Appeon File Server (setup.exe) can be found under %IIS_Web_Root%\appeon\plugin\fileservice. For PowerServer installed to the Java server, the WAR package of Appeon File Server (fileservice.war) can be found under %appeon%\plugin\fileservice.

You must configure and deploy the file server first in order to use the AppeonFileService object in the Appeon Workarounds PBL. In most cases Appeon File Server is deployed to the machine where the application server is installed. It can also be deployed separately. For example, when the file size is too big, uploading or downloading it will negatively impact the performance of the application server, you can deploy the file server separately to another machine.

In the following section, you will be guided to configure and deploy Appeon File Server to IIS (.NET Framework), WebLogic, WebSphere, JBoss, and JEUS. For more about the deploy instructions, refer to related documents of IIS, WebLogic, WebSphere, JBoss, and JEUS.

Deploying Appeon File Server to IIS
Installing the Appeon File Server

You will need to install first and then configure the Appeon File Server. For installing the file server to IIS, Appeon PowerServer provides a setup.exe file at %IIS_Web_Root%\appeon\plugin\fileservice.

Step 1: Double click the setup.exe file to start the setup.

If the "Installation Incomplete" error displays, please try the solution in the the section called “Appeon File Server Installation Incomplete” in PowerServer Troubleshooting Guide.

Figure 1. Appeon File Service Setup Wizard

Appeon File Service Setup Wizard


Step 2: Click the Next button and then the following window pops up. Select a Web site where the Appeon File Server will be installed.

Note that DO NOT change the name of Virtual directory otherwise Appeon File Server will fail to start.

Figure 2. Select Installation Address

Select Installation Address


Step 3: Click Next until the installation is complete.

Step 4: Go to directory where the Appeon File Server is installed, for example (C:\inetpub\wwwroot\fileservice).

Figure 3. Appeon File Server directory

Appeon File Server directory


Step 5: Select Properties from the right-click menu of the fileservice folder.

Step 6: In the Security tab page of the fileservice Properties window,

For IIS 7.5 or above, grant the IIS_IUSRS user with Full Control permission to this folder.

Figure 4. Grant Full Control (IIS7)

Grant Full Control (IIS7)

Uninstall Appeon File Server

Step 1: Go to Start | Control Panel | Add and Remove Programs.

Step 2: Select Appeon File Server and click Remove button.

Configuring the Appeon File Server

After deploying the Appeon File Server, follow steps below to configure it.

Open the appeonfileserver.xml in C:\Inetpub\wwwroot\fileservice.

<?xml version="1.0" encoding="UTF-8"?>
<webserver>
<!-- The value of attribute "value" must begin with either a single or double quote character. -->
 <file-path value="D:\appeon\upload" />
 <log-level value="3" />          <!--0 Error,1 Info,2 Func, 3 Debug-->
 <session-timeout value="3600" /> <!-- the unit is second  -->
 <allowed-file-types value="txt;doc;jpg;mpeg" ignorecase="true" />
 <max-file-size value="20" />     <!-- the unit is M --> 
 <users>
  <user name="test" password="password" />
  <user name="userA" password="userA" />
  <user name="userB" password="userB" />
 </users>
</webserver>

Modify the file according to your own demands.

Table 2. Settings specification value

Settings

The value of the setting specifies...

<file-path>

Specifies the directory to which files are saved after uploaded to the file server. Files are automatically saved in the "plugin" folder under the application directory when downloaded from the file server.

<log-level>

Specify the log level.

Value: 0 - Error

1 - Information

2 - Function

3 - Debug

<session-timeout>

Specifies the time, in seconds, that passes after the last request is processed before the session times out.

<allow-file-type>

Specifies the file types that can be uploaded. Use a ";" between two file types.

  1. "*" - Any file types are allowed. Note: Do not use "*" with other file types because "*" will not take any effect. For example, "*;text" means that only text file is allowed.

  2. Using a "-" before the file types - Any file type is allowed, excluding the listed ones. For example, "-text;doc;jpg;mpeg" means that any file type is allowed, excluding text, doc, jpg and mpeg files.

  3. "Ignorecase" - The file type is not case sensitive.

<max-file-size>

Specifies the maximum size (MB) of the file that can be uploaded.

<user>

Specifies the User Name and Password that can log on the file server. Multiple users are allowed as shown in the code example above.


Deploying Appeon File Server to WebLogic
Configuring the Appeon File Server

You will need to configure first and then deploy the Appeon File Server. Follow steps below to configure the Appeon File Server:

Step 1: On the machine where the Appeon File Server will be deployed, create an XML file wherever you like and name it whatever you wish. In this example, create an XML file named "appeonfileserver.xml" under D:\appeon\config directory.

Step 2: Copy the following code to the XML file.

<?xml version="1.0" encoding="UTF-8"?>
<fileserver>
 <file-path value="D:\appeon" />
 <session-timeout value="3600" />
 <allowed-file-types value="txt;doc;jpg;mpeg" ignorecase="true" />
 <max-file-size value="20" />
 <users>
  <user name="userA" password="userA" />
  <user name="userB" password="userB" />
 </users>
</fileserver>

Step 3: Modify the settings in the XML file if necessary.

Table 3. The settings specification value

Settings

The value of the setting specifies...

<file-path>

Specifies the directory to which files are saved after uploaded to the file server. Files are automatically saved in the "plugin" folder under the application directory when downloaded from the file server.

<session-timeout>

Specifies the time, in seconds, that passes after the last request is processed before the session times out.

<allow-file-type>

Specifies the file types that can be uploaded. Use a ";" between two file types.

  1. "*" - Any file types are allowed. Note: Do not use "*" with other file types because "*" will not take any effect. For example, "*;text" means that only text file is allowed.

  2. "-" - Exclude the file types listed after "-". For example, "-text;doc;jpg;mpeg" means that any file type is allowed, except for text, doc, jpg and mpeg files.

  3. "Ignorecase" - The file type is not case sensitive.

<max-file-size>

Specifies the maximum size (MB) of the file that can be uploaded.

<user>

Specifies the User Name and Password that can log on the file server. Multiple users are allowed as shown in the code example above.


Step 4: On the machine where the PowerServer is installed, unzip the fileservice.war (%powerserver%\plugin\fileservice) and find the web.xml file under the WEB-INF folder. Then open web.xml with a text editor. Replace the bold text with the name and directory of the XML file created in the previous steps.

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE web-app PUBLIC '-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN' 
'http://java.sun.com/dtd/web-app_2_3.dtd'>
<web-app>

<servlet>
 <servlet-name>fileservice</servlet-name>
 <servlet-class>com.appeon.fileserver.WebServiceDispatcher</servlet-class>
 <init-param>
  <param-name>config</param-name>
  <param-value>D:\appeon\config\appeonfileserver.xml</param-value>
 </init-param>
 <load-on-startup>1</load-on-startup>
</servlet>
<servlet>
 <servlet-name>uploadfile</servlet-name>
 <servlet-class>com.appeon.fileserver.UploadFile</servlet-class>
 <init-param>
  <param-name>config</param-name>
  <param-value>D:\appeon\config\appeonfileserver.xml</param-value>
 </init-param>
 <load-on-startup>1</load-on-startup>
</servlet>

<servlet-mapping>
 <servlet-name>fileservice</servlet-name>
 <url-pattern>/fileservice</url-pattern>
</servlet-mapping>

</web-app>

Step 5: Save the file and re-compress the fileservice folder to fileservice.war using WinZip, WinRAR or JDK. Do not use the other compression tools such as 7-zip.

Then follow the next section Deploying the Appeon File Server to deploy fileservice.war.

Deploying the Appeon File Server

After configuring the Appeon File Server, follow steps below to deploy it:

Step 1: On the machine where PowerServer is installed, access the WebLogic Server Administration Console in a Web browser.

Step 2: Click the Deployment link.

Figure 5. 


Step 3: Click the Install button and select the fileservice.war file at %powerserver%\plugin\fileservice.

Figure 6. 


Step 4: Click the Next button to use the default settings and then click the Finish button to finish the deployment of Appeon File Server.

Deploying Appeon File Server to WebSphere
Configuring the Appeon File Server

Configuring the Appeon File Server in the Java server such as WebLogic, WebSphere, JBoss, JEUS etc. is the same. Please refer to Configuring the Appeon File Server for WebLogic.

Deploying the Appeon File Server

After configuring the Appeon File Server, follow steps below to deploy it:

Step 1: On the machine where PowerServer is installed, access the WebSphere Administrative Console in a Web browser.

Step 2: Select Applications | Install New Applications from the left tree view. And then in the right page specify the path where the fileservice.war is (by default at %powerserver%\plugin\fileservice) and Context Root for the WAR file and click the Next button.

Figure 7. 


Step 3: Click Next with default settings until the file server is successfully installed on the WebSphere server.

Deploying Appeon File Server to JBoss
Configuring the Appeon File Server

Configuring the Appeon File Server in the Java server such as WebLogic, WebSphere, JBoss, JEUS etc. is the same. Please refer to Configuring the Appeon File Server for WebLogic.

Deploying the Appeon File Server

After configuring the Appeon File Server, follow steps below to deploy it. There are two methods to deploy the Appeon File Server in JBoss:

  • Automatic deploy

    Copy the file fileservice.war to the directory %JBoss installation root directory%\standalone\deployments and then start JBoss.

    The fileservice.war file will be deployed automatically.

  • Manual deploy

    1. Start JBoss and log in to JBoss console.

    2. Select Web Application in the left tree view and then click Add a new resource in the right page.

      Figure 8. PDF

      PDF


    3. Click Browse and locate the file fileservice.war.

      Figure 9. 


    4. Click Continue with default settings until the file server is successfully deployed in the JBoss server.

Deploying Appeon File Server to JEUS
Configuring the Appeon File Server

Configuring the Appeon File Server in the Java server such as WebLogic, WebSphere, JBoss, JEUS etc. is the same. Please refer to Configuring the Appeon File Server for WebLogic.

Deploying the Appeon File Server

After configuring the Appeon File Server, follow steps below to deploy it:

Copy the fileservice.war file to the directory %JEUS installation root directory%\webhome\autodeploy and then start JEUS server. The fileservice.war file will be deployed automatically.

Uploading and downloading files

After configuring and deploying the Appeon File Server, you can follow the steps below to upload files to or download files from the Appeon File Server.

Step 1: Add Appeon Workaround PBL to your PowerBuilder project.

Step 2: Define a variable and create an instance for the AppeonFileService object.

Step 3: Call of_logonfileserver to connect to the file server.

Step 4: Call of_appeonupload or of_appeondownload to upload or download files.

Step 5: Call of_logofffileserver to disconnect from the file server.

AppeonFileService object

AppeonFileService object provides service about the file uploading and downloading.

Functions for AppeonFileService object

AppeonFileService object provides the following functions to upload and download files:

of_logonfileserver

Description

Connects to the Appeon File Server.

Syntax

appeonfileservice.of_logonfileserver (string fileserveripaddress, long port, string connectstring )

Parameter

Description

appeonfileservice

An instance of an AppeonFileService object

fileserveripaddress

Protocol and IP address or machine name of the Appeon File Server. To use the HTTPS protocol, you should add "https://" before the IP address or machine name, for example, "https://192.168.168.52", otherwise, HTTP protocol (http://) will be used by default.

port

HTTP or HTTPS port of the application where the Appeon File Server is deployed.

connectstring

User name and password for connecting to the Appeon File Server. Format: "username=username;password=password". Use a semicolon ";" to separate the user name and password. The user name and password should be consistent with those specified in the appeonfileserver.xml configuration file.

Return value

Long.

Return values are:

0 - The logon is successful.

-1 - Connection to the file server fails.

-2 - The provided user name or password is invalid.

Code example

long ll_re
string info

ll_re = fileservice.of_logonfileserver ("192.168.168.52", 80, "username=userA;password=userA") 

if ll_re = 0 then
 info = "Logon to file server is successful."
elseif  ll_re = 1 then
 info = "Failed to connect to the file server."
else
 info = "Failed to connect to the file server."
end if

Messagebox( "ll_re="+string(ll_re),info)
of_logofffileserver

Description

Disconnects from the Appeon File Server.

Syntax

appeonfileservice.of_logofffileserver()

Parameter

Description

appeonfileservice

An instance of an AppeonFileService object

Return value

Long.

Return values are:

0 - The log-off is successful.

-1 - Connection to the Appeon File Server fails.

-2 - The session has timed out or the user has not logged off the file server.

Code example

long ll_re
string info

ll_re = fileservice.of_logofffileserver ( ) 

if ll_re = 0 then
 info = "Logoff file server is successful."
elseif  ll_re = 1 then
 info = "Failed to log off file server."
else
 info = "The session has timed out or the user has not logged off the file server."
end if
 
Messagebox( "ll_re="+string(ll_re),info)
of_appeonupload

Description

Uploads file to the Appeon File Server.

Syntax

appeonfileservice.of_appeonupload (string source, string destination, boolean isrename, ref long errorcode)

appeonfileservice.of_appeonupload (string destination, boolean isrename, ref long errorcode) (Web only)

appeonfileservice.of_appeonupload (boolean isrename, ref long errorcode) (Web only)

Parameter

Description

appeonfileservice

An instance of an AppeonFileService object.

source

The file name and directory of the source file.

For the mobile application, this parameter is required; it must be specified with a valid directory.

For the Web application, this parameter is optional. If no directory is specified here, a dialog box will be displayed prompting the user to select a file to upload.

destination

The destination directory on the file server where the file is uploaded.The directory specified here is a relative path to the file directory specified in the appeonfileserver.xml configuration file.

This parameter is optional to both the Web application and the mobile application.

isrename

Whether to rename the file if another file with the same name already exists.

errorcode

The error occurred when uploading files. Values are:

0 - Succeeded.

-1 - Connection to the file server fails.

-2 - ID error.

-3 - The format of the source file is forbidden.

-4 - Destination directory is invalid or the file is too large.

Return value

String.

Returns the URL of the uploaded file if it succeeds and returns an empty string if it fails.

Returns NULL if any argument is NULL.

Usage

If you want to delete an uploaded file, you must restart the file server after deleting it. Otherwise, you will fail to upload the file with the same name.

Code example

long ll_re
string info,ls_url

ls_url = fileservice.of_appeonupload ("C:\temp\1.pdf", "pdf_files", true, ll_re) 

if ll_re = 0 then
 info = "Upload is successful."
elseif  ll_re = 1 then
 info = "Failed to upload the file."
else
 info = "Other errors."
end if

Messagebox("ll_re="+string(ll_re),info+"~r~nurl="+ls_url)
of_appeondownload

Description

Downloads the specified file from the Appeon File Server.

Syntax

appeonfileservice.of_appeondownload (string source)

appeonfileservice.of_appeondownload (string source, string target)

Parameter

Description

appeonfileservice

An instance of an AppeonFileService object.

source

The file name and directory of the file which will be downloaded. The directory specified here is a relative path to the file directory specified in the appeonfileserver.xml configuration file.

target

(Optional) The destination directory on the client machine where the file will be saved after downloaded from the file server.

For the mobile application, this parameter is ignored, as the file will be automatically saved to the "plugin" folder under the application directory. You can determine the directory for the current application by calling the AppeonGetCacheDir function.

For the Web application, this parameter is optional. If no directory is specified here, a dialog box will be displayed prompting the user to select a location to save the file.

Return value

Long.

Return values are:

0 - The file is successfully downloaded.

-1 - The file download failed or exceptions occurred.

-3 - File name is empty.

NULL if any argument is NULL.

Code example

The following code example is to download a PDF file named "1.pdf" from the "pdf_files" folder under the specified directory on the Appeon File Server. On the Web client, the file will be saved to "C:\" as specified by the target parameter; while on the mobile device, the file will be automatically saved to the "plugin" folder for the current application, despite that the target parameter is set to "C:\".

long ll_re
string info

ll_re = fileservice.of_appeondownload ("pdf_files\1.pdf", "C:\") 

if ll_re = 0 then
 info = "Download is successful."
else
 info = "Other errors."
end if

Messagebox ("ll_re="+string(ll_re),info)

The following code example is to view the PDF file (named "1.pdf" located on the local C drive) via Internet Explorer. This is effective for the Web client only.

string ls_file

ls_file = "~"C:\Program Files\Internet Explorer\iexplore.exe~" C:\1.pdf"
Messagebox("",ls_file)
run(ls_file)
of_FileExists

Description

Reports whether the specified file exists on the Appeon File Server.

Syntax

appeonfileservice.of_FileExists (String filename)

Parameter

Description

appeonfileservice

An instance of the AppeonFileService object.

filename

A string whose value is the name of a file.

Return value

Long.

1 - The file exists.

0 - The file does not exist on the Appeon File Server.

-1 - Failed to connect to the Appeon File Server.

Code example

long ll_re
string info

ll_re = fileservice.of_fileexists ("pdf_files\1.pdf") 

if ll_re =1 then
 info = "The file exists."
elseif ll_re =0 then
 info = "The file does not exist on the file server."
else 
 info = "Other errors."
end if

Messagebox( "ll_re="+string(ll_re),info)
Properties for AppeonFileService object

AppeonFileService object provides the following properties (private instances) to upload and download files:

  • is_FileServerName instance: Indicates the name of the file server.

  • is_LogOnParams instance: Indicates the connection string for logging into the file server.

  • il_Id instance: Long. Indicates the ID number returned from the file server when logon has succeeded.

is_FileServerName

Description

Indicates the IP address or machine name of the file server. This property is initialized after the of_LogOnFileServer function is called.

Return value

String.

is_LogOnParams

Description

Indicates the connection string for logging into the file server. This property is initialized after the of_LogOnFileServer function is called.

Return value

String.

il_Id

Description

Indicates the ID number returned from the file server when logon has succeeded. This property is initialized after the of_LogOnFileServer function is called. It is used by the file server to validate the client.

Return value

Long.