WO2016082549A1 - 一种建立设备映射的方法及装置 - Google Patents
一种建立设备映射的方法及装置 Download PDFInfo
- Publication number
- WO2016082549A1 WO2016082549A1 PCT/CN2015/083283 CN2015083283W WO2016082549A1 WO 2016082549 A1 WO2016082549 A1 WO 2016082549A1 CN 2015083283 W CN2015083283 W CN 2015083283W WO 2016082549 A1 WO2016082549 A1 WO 2016082549A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- client
- state
- identification information
- physical device
- physical
- Prior art date
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/10—Program control for peripheral devices
- G06F13/105—Program control for peripheral devices where the programme performs an input/output emulation function
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/10—Program control for peripheral devices
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/38—Information transfer, e.g. on bus
- G06F13/40—Bus structure
- G06F13/4063—Device-to-bus coupling
- G06F13/4068—Electrical coupling
- G06F13/4081—Live connection to bus, e.g. hot-plugging
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2213/00—Indexing scheme relating to interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F2213/0042—Universal serial bus [USB]
Definitions
- the present invention relates to the field of electronic information technology, and in particular, to a method and an apparatus for establishing device mapping.
- a local terminal such as a keyboard, a mouse, a USB (Universal Serial Bus) peripheral, a headset, and a microphone
- a local terminal such as a keyboard, a mouse, a USB (Universal Serial Bus) peripheral, a headset, and a microphone
- the software program for implementing the remote virtual desktop system on the client may be referred to as a client, and is used on the server.
- a software program that implements a remote virtual desktop system can be referred to as a server.
- the client accesses the server with the remote virtual desktop system through the client running on the client and invokes the client's input and output devices through the remote virtual desktop system.
- the client can be a terminal with a Linux system, and the physical USB device is inserted into the terminal, and is detected by the terminal through traversal or monitoring, and the USB physical device is bound to the USB by default.
- Device driver the physical USB device is inserted into the terminal, and is detected by the terminal through traversal or monitoring, and the USB physical device is bound to the USB by default.
- the terminal After the USB physical device is inserted into the terminal, the terminal reads the description information of the USB physical device through the kernel of the operating system and stores it in the memory of the terminal.
- the USB client reads the description information from the memory and according to the read description information.
- the USB client After the USB physical device is identified, the USB client then binds the USB physical device to the universal drive and redirects the USB physical device to the remote virtual desktop system through the universal drive.
- some applications in the terminal also use a physical USB device inserted into the terminal. For example, if the program 1 exists in the user state of the terminal, and the program 1 also needs to use the physical USB device, the current will be The kernel driver bound to the USB physical device is forcibly unbound.
- USB devices cannot be mapped to servers with remote virtual desktop systems, resulting in remote virtual tables
- the application in the surface system cannot normally call the input and output devices of the local terminal.
- the embodiments of the present invention provide a method and an apparatus for establishing a device mapping, which can prevent the mapping between the physical device and the virtual device from being disconnected, and ensure that the application in the remote virtual desktop system can normally use the physical device without being interrupted.
- an embodiment of the present invention provides a method for establishing a device mapping, where the method is used in a remote desktop system, where the remote desktop system includes a client and a server, and the client is externally connected with a physical device.
- the server includes a virtual device; the universal driver and the third-party driver are installed on the client, and the application existing on the client includes at least a first application and a second application;
- the first application is the remote desktop system Client program, the first application is configured to control the physical device by the universal driver, and establish a mapping between the physical device and the virtual device, the first application identifying the physical device Triggering the client to load the universal driver;
- the second application is configured to control the physical device by the third-party driver, and when the second application identifies the physical device, triggering the The client loads the third party driver;
- the method includes:
- the client acquires identification information of the physical device, the identification information includes a key field for describing the physical device, and the key field is used by an application existing on the client to identify the physical device ;
- the client modifies the identification information from a first state to a second state; wherein the first state is in the first state Key fields in the identification information can be read by an application present on the client and used to identify the physical device; a key field in the first state and a key field in the second state Not identical, the key field in the identification information in the second state cannot be An application that exists on the client is used to identify the physical device.
- the modifying the identification information from the first state to the second state includes:
- the client inverts the key segment bitwise, and uses the identification information of the bit segment inverted bit segment as the identification information in the second state.
- the method further includes:
- the client Before modifying the identification information from the first state to the second state, the client determines, according to the request information sent by the server, whether a device exclusive event of the physical device pointed by the request information is triggered;
- the client modifies the identification information from the first state to the second state.
- the method further includes:
- mapping between the physical device and the virtual device When the mapping between the physical device and the virtual device is disconnected, detecting whether the physical device is recorded in an exclusive list, and if yes, the client modifying the identification information from the second state to the first a state, wherein after the client modifies the identification information from a first state to a second state, the physical device is recorded by the client in the exclusive list;
- the physical device includes a USB device
- the request information is carrying the additional information.
- the USB redirection request, the additional information indicating that the device exclusive event of the USB device is triggered or not triggered, the method further includes:
- the client modifies the identification information from the first state to the second state by using the universal driver, and records the physical device in the Said in the exclusive list; and through the universal driver, the processing result of the USB redirection is transmitted to the client program;
- the client transmits the processing result of the USB redirection to the client program through the universal driver.
- an embodiment of the present invention provides an apparatus for establishing a device mapping, the apparatus being for a client in a remote desktop system, the remote desktop system including the client and a server, the client Externally connected to a physical device, the server includes a virtual device; a universal driver and a third-party driver are installed on the client, and an application existing on the client includes at least a first application and a second application; the first application a client program of the remote desktop system, the first application is configured to control the physical device by the universal driver, and establish a mapping between the physical device and the virtual device, the first application When the physical device is identified, the client is triggered to load the universal driver; the second application is configured to control the physical device by the third-party driver, and the second application identifies the physical When the device is triggered, the client is triggered to load the third-party driver;
- the device includes:
- a first acquiring module configured to acquire identification information of the physical device, where the identification information includes a key segment for describing the physical device, where the key segment is used for an application identifier that exists on the client Physical equipment;
- a first processing module configured to identify, according to the identification information, the first application
- the client modifies the identification information from a first state to a second state; wherein a key field in the identification information in the first state can be applied by an application on the client Read by the program and used to identify the physical device; the key field in the first state is different from the key segment in the second state, and is in the identification information in the second state A key field cannot be used by an application present on the client to identify the physical device.
- the first processing module includes:
- the first processing submodule is configured to invert the bit segment and use the identification information of the bit segment inverted by the bit as the identification information in the second state.
- the method further includes:
- a determining module configured to determine, according to the request information sent by the server, whether a device exclusive event of the physical device pointed to by the request information is triggered, before modifying the identification information from the first state to the second state;
- a second processing module configured to: if the device triggers the device exclusive event, after the client identifies the physical device pointed to by the request information according to the identification information, modify the identification information from the first state to the first state Two states.
- the method further includes:
- a third processing module configured to detect, when the mapping between the physical device and the virtual device is disconnected, whether the physical device is recorded in an exclusive list, and if yes, the client sends the identification information by The second state is modified to a first state, wherein after the client modifies the identification information from the first state to the second state, the physical device is recorded by the client in the exclusive list;
- the physical device includes a USB device, and the request information is a USB redirection request that carries additional information.
- the additional information indicates that the device exclusive event of the USB device is triggered or not triggered, and the device further includes:
- a fourth processing module configured to receive, by the client program, the USB redirection request sent by the server, and transmit the USB redirection request to the universal driver;
- the identification information is modified from the first state to the second state by the universal driving, and the physical device is recorded in the exclusive list. And transmitting, by the universal driver, the processing result of the USB redirection to the client program;
- the processing result of the USB redirection is transmitted to the client program by the universal driver.
- the method and device for establishing device mapping provided by the embodiment of the present invention can obtain the identification information of the device after the client identifies the device according to the identification information, and then modify the identification information from the first state to the second state to enable the client.
- the application that is developed based on the user mode driver in the machine, that is, the second application, cannot identify the physical device.
- the present invention can avoid the chaotic operation of the physical device by modifying the state of the identification information of the device.
- the mapping between the physical device and the virtual device is not disconnected, and the application in the remote virtual desktop system can be used normally without interruption.
- FIG. 1 is a schematic diagram of a specific application scenario of the prior art
- FIG. 2 is a flowchart of a method for establishing device mapping according to an embodiment of the present invention
- FIG. 3 is a flowchart of another method for establishing device mapping according to an embodiment of the present disclosure
- FIG. 4 is a flowchart of another method for establishing device mapping according to an embodiment of the present invention.
- FIG. 5 and FIG. 6 are flowcharts of another method for establishing device mapping according to an embodiment of the present invention.
- FIG. 7 is a flowchart of another method for establishing device mapping according to an embodiment of the present invention.
- FIG. 7a is a specific data interaction flowchart of a method for establishing device mapping according to an embodiment of the present invention.
- FIG. 8 is a schematic structural diagram of an apparatus for establishing device mapping according to an embodiment of the present disclosure.
- 8a, 8b, 8c, and 8d are schematic structural diagrams of an apparatus for establishing device mapping according to an embodiment of the present invention.
- FIG. 9 is a schematic structural diagram of a client device according to an embodiment of the present invention.
- the embodiment of the present invention may be applied to a remote desktop system, where the remote desktop system includes at least a client and a server, the client is externally connected with a physical device, the server includes a virtual device, and the universal driver and the first driver are installed on the client.
- the three-party driver the application existing on the client includes at least a first application and a second application; the first application is a client program of the remote desktop system, and the first application is used to pass the
- the universal drive controls the physical device and establishes a mapping between the physical device and the virtual device, and when the first application identifies the physical device, triggering the client to load the universal driver; Second application When the physical device is controlled by the third-party driver, when the second application identifies the physical device, the client is triggered to load the third-party driver.
- the program 1 is an application developed based on user mode, and can be used as a second application; the USB client can be used as the first application.
- the USB client or the USB server sends a request to the client, triggering the client to use the USB universal driver to enable redirection for the physical USB device, and the interface is forcibly unbundled.
- the physical USB device is bound to the USB device driver by default, and then binds its USB universal driver to the physical USB device, so that the USB client occupies the physical USB device and uses the physical USB device for redirection.
- the USB server is located in the server, the USB device driver and the USB universal driver work in the kernel state, and belong to the kernel mode driver; and the "user-driven application developed based on the user mode" will force unbind the physical USB device through the relevant system API.
- a bound USB kernel-mode driver such as a USB universal driver, then interacts directly with the physical USB device to preempt the physical USB device.
- An embodiment of the present invention provides a method for establishing a device mapping, as shown in FIG. 2, including:
- the client acquires identification information of the physical device.
- the identification information includes a key field for describing the physical device, and the key field is used by an application existing on the client to identify the physical device.
- the key fields included in the identification information may be one or a combination of multiple types. For example, the possible combinations of several key fields in the MAC OS are described in Table 1:
- the combination manner of the key fields in the identification information is not limited, and may be According to the combination of existing standard protocols, it can also be set by the technician according to the specific situation.
- the client's operating system generally does not pay attention to the idVendor+idProduct field, but will pay attention to other Identification field.
- the client's operating system reads and stores the key fields into the memory, and how the application in the client can read the key fields in the memory can be implemented by referring to the prior art.
- the client when the device is inserted on the client, and the client uses the generic driver's subsystem to listen to the event notification of the physical USB device insertion, the client acquires the identification information of the physical USB device inserted into the client; or, Before the client subsystem is up and running, the physical USB device has been inserted into the client, and the client periodically obtains the identification information of the physical USB device through an automatic traversal query.
- the client modifies the identification information from a first state to a second state.
- the key field in the identification information in the first state can be read by an application existing on the client, and used to identify the physical device; the key segment in the first state is The key fields in the second state are different, and the key fields in the identification information in the second state cannot be used by the application existing on the client to identify the physical device.
- the acquired identification information is modified by the client from the first state to the second state.
- the first application since the first application has identified the physical device according to the identification information before the modification, the first application can identify the physical device according to the identification information in the second state, which is not limited.
- the method for establishing device mapping is provided by the embodiment of the present invention. After the device obtains the identification information of the device and identifies the device according to the identification information, the identification information is modified from the first state to the second state, so that the client is in the client.
- the user device-driven development application that is, the second application program, cannot identify the physical device.
- the present invention can avoid the chaotic operation of the physical device by modifying the state of the identification information of the device.
- the mapping between physical devices and virtual devices is not It is disconnected to ensure that the application in the remote virtual desktop system can use the physical device without interruption.
- the identification information includes a key field in a kernel driver of the physical device, and a default state of the key field is the first state. Therefore, on the basis of the implementation shown in FIG. 2, 102 can be implemented as 201 as shown in FIG. 3:
- the client inverts the key field bitwise, and uses the identification information of the key segment inverted by bit as the identification information in the second state.
- the client segment having the subsystem running the universal driver reverses the key field in the identification information by bit, which includes the bitwise inversion
- the identification information of the subsequent key segment is used as the identification information in the second state, and after the modification process is performed, the device may be recorded in the exclusive list, so that when the mapping between the physical device and the virtual device is disconnected, or When the device exclusive event is canceled, the identification information is modified from the second state to the first state.
- the client modifies the identification information from the first state to the second state
- the physical device is recorded by the client in the exclusive list.
- a client having a subsystem running a universal driver acquires identification information of the physical USB device, identifies the inserted physical USB device according to the identification information, and identifies the physical USB device for udev.
- the manner of modifying the identification information from the first state to the second state is not limited to bitwise negation, and may include other modification manners.
- the client performs encryption calculation on the key field by using a commonly used encryption algorithm, and obtains a length consistent with the length of the key field.
- the encrypted field and the encrypted field is used as the identification information of the second state.
- the client shifts the key segment to the left or right by a field shifting method, and obtains a shifted key segment that is consistent with the length of the key segment.
- the identification information including the shifted key segment is included as the identification information of the second state.
- idProduct (product ID) 1 field in the identification information
- the client identifies the device that needs to be mapped in an exclusive manner according to the identification information
- the identification information in the first state and the physical device mapped in an exclusive manner may be recorded in the exclusive list, so that when the mapping is disconnected or When the device exclusive event is canceled, the client modifies the identification information including the key field from the second state to the first state.
- a method for establishing device mapping is provided by the embodiment of the present invention.
- the key segment in the identification information is reversed by bit position.
- the first state is modified to the second state, so that the application that is developed based on the user state in the client, that is, the second application, cannot identify the physical device, and the present invention can modify the identification information by comparing with the prior art.
- Key segment which modifies the status of the device's identification information, avoids the chaotic management of the physical device, and prevents the mapping between the physical device and the virtual device from being disconnected, ensuring that the application in the remote virtual desktop system can use the physical device normally. Not interrupted.
- the client Before modifying the identification information from the first state to the second state, the client determines, according to the request information sent by the server, whether a device exclusive event of the physical device pointed by the request information is triggered.
- three physical USB devices are inserted on the client, wherein the physical USB device 1 and the physical USB device 2 need to be mapped with the virtual device, and the physical USB device 3 does not need to establish a mapping with the virtual device, and then acquires three physical USB devices.
- the server judges according to the information of the three physical USB devices in combination with the policy configuration, confirms that the physical USB device 1, the physical USB device 2 needs to be redirected, and whether it is exclusive, the physical USB device 3 No redirection is required; request information is generated based on the information of each physical USB device and forwarded to the universal driver through the client.
- the request information includes at least an instruction of whether to redirect, and whether to redirect in an exclusive manner.
- the request information is used to indicate the processing mode of the physical USB device according to the request information returned by the server, and the processing manner of the physical USB device includes at least exclusive redirection.
- Non-exclusive redirection and no redirection for example, the request information records that the state of the physical USB device 1 is exclusive redirection, the state of the physical USB device 2 is non-exclusive redirection, and the state of the physical USB device 3 is not redirected.
- the client determines that the physical USB device 1 triggers the device exclusive event according to the request information, and the physical USB device 2 performs redirection by the prior art, and the physical USB device 3 does not trigger the device redirection event.
- the client modifies the identification information from the first state to the second state. status.
- the non-exclusive processing can be implemented without modifying the state information of the physical device, and the physical device is not added to the exclusive list.
- the client After the client receives the request information sent by the server, it is determined according to the request information that the physical USB device 1 triggers the device exclusive redirection event, the physical USB device 2 triggers the non-exclusive redirection event, and the physical USB device 3 does not trigger the device redirection event. , then the client identifies it based on the identification information After the physical USB device 1 pointed to by the request information, the identification information of the physical USB device 1 is changed from the first state to the second state; the physical USB device 2 triggers the non-exclusive redirection event, and the physical USB device 3 does not trigger the device redirection event. , the modification of the state information of the physical device is not performed, and the physical device is not added to the exclusive list.
- the subsystem loaded with the USB kernel driver first detects that the physical USB device is inserted into the client, and reads the identification information of the physical USB device and other descriptor information, such as: device descriptor, interface description. , a configuration descriptor, etc., and then broadcast the insertion event notification of the physical USB device insertion client to each listener, so as to notify the client or the server of the identification information of the physical USB device, and ask whether the physical USB device needs to be mapped.
- the client or the server returns the request information according to the policy configuration, the request information relates to whether the redirect is required, and the redirect mode instruction if the redirect is used.
- the identification information may be acquired multiple times, that is, after the request information is acquired, the identification information may be acquired again as needed.
- the method for establishing device mapping can determine, according to the request information sent by the server, triggering an exclusive event for the physical device pointed to by the request information, acquiring the identification information of the device at the client, and identifying the device according to the identification information.
- the identification information is modified from the first state to the second state, so that the application that is developed based on the user state in the client, that is, the second application, cannot identify the physical device, compared to the prior art
- the invention can determine, according to the request information sent by the server, triggering an exclusive event for the physical device pointed to by the request information, and modifying the state of the identification information of the device that triggers the exclusive event, thereby avoiding chaos of the drive management of the physical device, and making the physical device and the virtual device The mapping is not broken, ensuring that the application in the remote virtual desktop system can use the physical device without interruption.
- the client Modifying the identification information from the second state to a first state and deleting the physical device from the exclusive list. Therefore, based on the implementation shown in FIG. 4, it can also be implemented as As shown in Figure 5, or as shown in Figure 6:
- mapping between the physical device and the virtual device is disconnected, check whether the physical device is recorded in an exclusive list.
- mapping between the physical device and the virtual device is disconnected, or when the device exclusive event is canceled, the physical device is recorded in an exclusive list, then the client identifies the The information is modified from the second state to a first state.
- the physical device is recorded by the client in the exclusive list.
- mapping between the physical device and the virtual device is disconnected, or when the device exclusive event is canceled, it is detected whether the physical device is recorded in the exclusive list, and if the physical device has been recorded in the exclusive list, the client will identify the information. , the second state is modified to the first state, and the physical device is deleted from the exclusive list; if the physical device is not recorded in the exclusive list, no processing is performed.
- the method for establishing device mapping can determine, according to the request information sent by the server, triggering an exclusive event for the physical device pointed to by the request information, acquiring the identification information of the device at the client, and identifying the device according to the identification information.
- the identification information is modified from the first state to the second state, so that the application that is developed based on the user state in the client, that is, the second application, cannot identify the physical device, thereby completing the physical device and the virtual device.
- Mapping when the mapping between the physical device and the virtual device is disconnected, or when the device exclusive event is canceled, if the physical device is recorded in the exclusive list, the client modifies the identification information from the second state to the first state, And remove the physical device from the exclusive list.
- the client of the present invention modifies the identification information from the first state to the second state, and when the mapping between the physical device and the virtual device is disconnected, or when the device exclusive event is canceled,
- the physical device is recorded in the exclusive list, and the client modifies the identification information from the second state to the first state, and the physical device is from the exclusive column.
- the table is deleted to avoid the chaos of the drive management of the physical device, so that the mapping between the physical device and the virtual device is not disconnected, and the application in the remote virtual desktop system can be used normally without interruption.
- the physical device includes a USB device
- the request information is a USB redirection request carrying additional information, where the additional information indicates that the device exclusive event of the USB device is triggered or not triggered, and therefore,
- the implementation manner shown in FIG. 7 can also be implemented:
- the client receives the USB redirection request sent by the server by using the client program, and transmits the USB redirection request to the universal driver.
- the client modifies the identification information from the first state to the second state by using the universal driver, and records the physical device. In the exclusive list; and transmitting the processing result of the USB redirection to the client program by the universal driver.
- the client transmits the processing result of the USB redirection to the client program by using the universal driver.
- a software program used to implement a remote virtual desktop system on a client may be referred to as a client, and a software program on the server for implementing a remote virtual desktop system may be referred to as a server.
- a software program on the server for implementing a remote virtual desktop system may be referred to as a server.
- the specific data interaction process is as follows:
- the client reads the package data from the subsystem that is running the generic driver, extracting the USB device Related data information, and the related data information of the newly inserted USB device is sent to the server through the virtual channel;
- the server receives the related data information of the USB device, and combines the currently configured redirection policy and the exclusive policy to determine whether the newly inserted USB device allows mapping; if necessary, it is determined whether the newly inserted USB device allows mapping or not. This embodiment does not specifically limit this.
- the server sends a notification to the client to enable the USB device redirection, and "whether exclusive" information, and the client forwards the request carrying the additional information and the server to open the USB device redirection to the client.
- the subsystem processing of the universal driver is running. It should be noted that when the additional information indicates that the device exclusive event of the USB device is triggered, the client modifies the identification information from the first state to the second state through the universal driver, and records the physical device. In the exclusive list, and through the universal driver, the processing result of the USB redirection is transmitted to the client program; when the additional information indicates that the device exclusive event of the USB device is not triggered, the client sends the result of the USB redirection to the client through the universal driver. Terminal program transmission;
- the subsystem running the universal driver receives the request and additional information, and opens the redirection in different ways, replaces and claims the interface to the USB device, and notifies the client to read the encapsulated processing result, and turns on the redirection of the USB device.
- the client reads the encapsulated processing result from the virtual desktop system running the bus driver, extracts the response result, and sends the response result to the server;
- the server analyzes the received response result, determines whether the redirection is successfully enabled, and if successfully opened, sends a notification to create a virtual USB device to the virtual desktop system that is running the bus driver;
- the virtual desktop system running the bus driver creates a virtual USB device according to the request sent by the server, and then the server senses that the new USB device appears and processes it accordingly.
- the method for establishing device mapping is provided by the embodiment of the present invention. After the device obtains the identification information of the device and identifies the device according to the identification information, the identification information is modified from the first state to the second state, so that the client is in the client. An application developed based on user mode, ie a second application, The physical device cannot be identified. Compared with the prior art, the present invention can modify the state of the identification information of the device, avoid the chaos of the drive management of the physical device, and prevent the mapping between the physical device and the virtual device from being disconnected, thereby ensuring remote virtualization. An application in the desktop system can use the physical device without interruption.
- An embodiment of the present invention provides an apparatus 60 for establishing a device mapping.
- the apparatus 60 is used for a remote desktop system, where the remote desktop system includes a client and a server, and the client is externally connected with a physical entity.
- the server includes a virtual device; a universal driver and a third-party driver are installed on the client, and an application existing on the client includes at least a first application and a second application;
- the first application is the a client program of the remote desktop system, the first application is configured to control the physical device by the universal driver, and establish a mapping between the physical device and the virtual device, the first application identifying the
- the client is triggered to load the universal driver;
- the second application is used to control the physical device by the third-party driver, and when the second application identifies the physical device, Triggering the client to load the third party driver;
- the device 60 includes:
- the first obtaining module 61 is configured to acquire identification information of the physical device, where the identification information includes a key segment for describing the physical device, and the key segment is used for application identification existing on the client The physical device.
- a first processing module 62 configured to: after the first application identifies the physical device according to the identification information, the client modifies the identification information from a first state to a second state; a key field in the identification information of the first state can be read by an application existing on the client, and used to identify the physical device; a key segment in the first state is in the The key fields of the second state are different, and the key fields in the identification information in the second state cannot be used by the application existing on the client to identify the physical device.
- the first processing module 62 includes:
- the first processing sub-module 621 is configured to invert the bit segment and use the identification information of the bit segment inverted by the bit as the identification information in the second state.
- the device 60 further includes:
- the determining module 63 is configured to determine, according to the request information sent by the server, whether the device exclusive event of the physical device pointed by the request information is triggered, before modifying the identification information from the first state to the second state.
- the second processing module 64 is configured to: if the device triggers the device exclusive event, after the client identifies the physical device pointed by the request information according to the identification information, modify the identification information from the first state to Second state.
- the device 60 further includes:
- the third processing module 65 is configured to detect, when the mapping between the physical device and the virtual device is disconnected, whether the physical device is recorded in an exclusive list, and if yes, the client sends the identification information by The second state is modified to a first state, wherein the physical device is recorded by the client in the exclusive list after the client modifies the identification information from a first state to a second state ;
- the physical device includes a USB device
- the request information is a USB redirection request carrying additional information
- the additional information indicates a device of the USB device.
- the exclusive event triggers or does not trigger.
- the device 60 further includes:
- the fourth processing module 66 is configured to receive, by the client program, the USB redirection request sent by the server, and transmit the USB redirection request to the universal driver;
- Passing the pass when the additional information indicates that the device exclusive event of the USB device is triggered Modifying, by the driver, the identification information from the first state to the second state, and recording the physical device in the exclusive list; and transmitting, by the universal driver, the processing result of the USB redirection to the client program transmission;
- the processing result of the USB redirection is transmitted to the client program by the universal driver.
- the device for establishing device mapping is provided by the embodiment of the present invention. After the device obtains the identification information of the device and identifies the device according to the identification information, the identification information is modified from the first state to the second state, so that the client is in the client.
- the user device-driven development application that is, the second application program, cannot identify the physical device.
- the present invention can avoid the chaotic operation of the physical device by modifying the state of the identification information of the device.
- the mapping between the physical device and the virtual device is not disconnected, ensuring that the application in the remote virtual desktop system can use the physical device without interruption.
- the embodiment of the present invention provides a client device 70.
- the method includes at least a processor 701, a network interface 702, a memory 703, and a communication bus 704.
- the communication bus 704 is used to implement the processor 701. a communication between the network interface 702 and the memory 703; the memory 703 is configured to store data involved in the running of the client device 70; optionally, a user interface 705 is also included.
- the memory 703 may include a high speed RAM memory and may also include a non-volatile memory such as at least one disk memory.
- the memory 703 can optionally include at least one storage device located remotely from the aforementioned processor 701; wherein the client device 70 is for a remote desktop system, the remote desktop system including a client device 70 and a server, The client device 70 is externally connected with a physical device, the server includes a virtual device; the client device 70 is installed with a universal driver and a third-party driver, and the application stored on the client device 70 includes at least a first application and a a second application; the first application is a client program of the remote desktop system, the first application is configured to control the physical device by the universal drive, and establish the physical device and Mapping the virtual device, the first application identifying the physical device, triggering the client device 70 to load the universal driver; the second application is configured to control the third-party driver And the physical device, when the second application identifies the physical device, triggering the client device 70 to load the third-party driver.
- the memory 703 stores the following elements, executable modules or data structures, or a subset thereof, or their extended set:
- the operating service system 7031 includes various business system programs for implementing various basic services and processing hardware-based tasks.
- the application 7032 includes various applications for implementing various application services.
- the network interface 702 is configured to acquire identification information of the physical device, where the identification information includes a key segment for describing the physical device, and the key segment is used by the client.
- An application present on the machine device 70 identifies the physical device.
- the processor 701 configured to: after the first application identifies the physical device according to the identification information, the client device 70 modifies the identification information from a first state to a second state; a key field in the identification information in the first state can be read by an application existing on the client device 70 and used to identify the physical device; a keyword in the first state The segment is different from the key field in the second state, and the key field in the identification information in the second state cannot be used by the application existing on the client device 70 to identify the Physical device.
- the processor 701 is specifically configured to perform bitwise inversion on the key field, and include, as the second state, identification information including a bit segment inverted bit field. Identify information.
- the processor 701 is further configured to determine, according to the request information sent by the server, the physics pointed by the request information, before modifying the identification information from the first state to the second state. Whether the device exclusive event of the device is triggered;
- the client device 70 recognizes according to the identification information. After the physical device pointed to by the information is requested, the identification information is modified from the first state to the second state.
- the processor 701 is further configured to: when the mapping between the physical device and the virtual device is disconnected, detecting whether the physical device is recorded in an exclusive list, and if yes, the client The device device 70 modifies the identification information from the second state to a first state, wherein after the client device 70 modifies the identification information from the first state to the second state, the physical device is The client device 70 is recorded in the exclusive list;
- the client device 70 modifies the identification information from the second state to the first status.
- the physical device includes a USB device
- the request information is a USB redirection request carrying additional information, where the additional information indicates that the device exclusive event of the USB device is triggered or not triggered
- the device 701 is further configured to receive, by using the client program, the USB redirection request sent by the server, and transmit the USB redirection request to the universal driving;
- the identification information is modified from the first state to the second state by the universal driving, and the physical device is recorded in the exclusive list. And transmitting, by the universal driver, the processing result of the USB redirection to the client program;
- the processing result of the USB redirection is transmitted to the client program by the universal driver.
- the client device of the present invention is capable of acquiring the identification information of the device after the client device identifies the device according to the identification information, and then modifying the identification information from the first state to the second state, so that the client device is in the client device.
- the user device-driven development application that is, the second application program, cannot identify the physical device.
- the present invention can avoid the chaotic operation of the physical device by modifying the state of the identification information of the device. Physical and virtual devices The shot is not disconnected, ensuring that the application in the remote virtual desktop system can use the physical device without interruption.
- the storage medium may be a magnetic disk, an optical disk, a read-only memory (ROM), or a random access memory (RAM).
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Computer Hardware Design (AREA)
- Computer And Data Communications (AREA)
- Information Transfer Between Computers (AREA)
Abstract
一种建立设备映射的方法及装置,涉及电子信息技术领域,能够使物理设备与虚拟设备的映射不被断开,保证远程虚拟桌面系统中的应用能够正常使用该物理设备而不被中断。所述客户机获取所述物理设备的识别信息(101);在所述第一应用程序根据所述识别信息识别到所述物理设备后,所述客户机将所述识别信息由第一状态修改为第二状态(102)。适用于远程桌面系统。
Description
本发明涉及电子信息技术领域,尤其涉及一种建立设备映射的方法及装置。
目前,通常通过远程桌面协议,将本地终端的各种输入输出设备,比如:键盘,鼠标,USB(Universal Serial Bus,通用串行总线)外设,耳机和麦克风等,映射到具有远程虚拟桌面系统的服务器。
在现有技术中,远程虚拟桌面系统的在运行过程中至少需要客户机和服务器这两种硬件设备,在客户机上用于实现远程虚拟桌面系统的软件程序可以称为客户端,在服务器上用于实现远程虚拟桌面系统的软件程序可以称为服务端。客户机通过客户机上运行的客户端接入具有远程虚拟桌面系统的服务器,并通过远程虚拟桌面系统调用客户机的输入输出设备。例如:如图1所示,客户机可以为具有Linux系统的终端,物理USB设备插入终端,被终端通过遍历或监听插拔等手段检测到,并在缺省状态下,USB物理设备绑定USB设备驱动。USB物理设备在插入终端后,终端通过操作系统的内核读取USB物理设备自带的描述信息并存入终端的内存中,USB客户端从内存中读取描述信息并根据所读取的描述信息识别到USB物理设备,之后USB客户端将USB物理设备绑定至通用驱动,并通过通用驱动控制USB物理设备重定向至远程虚拟桌面系统。但是在实际应用中,终端中的某些应用程序也会使用插入终端的物理USB设备,比如在终端的用户态中存在程序1,且程序1也需要使用物理USB设备,此时就会将当前USB物理设备所绑定的内核驱动强制解绑,若当前USB物理设备所绑定的驱动为USB客户端进行重定向的过程中所用的通用驱动,则就会导致重定向的过程中断,使得物理USB设备无法正常映射到具有远程虚拟桌面系统的服务器,导致远程虚拟桌
面系统中的应用不能正常调用本地终端的输入输出设备。
发明内容
本发明的实施例提供一种建立设备映射的方法及装置,能够使物理设备与虚拟设备的映射不被断开,保证远程虚拟桌面系统中的应用能够正常使用该物理设备而不被中断。
为达到上述目的,本发明的实施例采用如下技术方案:
第一方面,本发明的实施例提供一种建立设备映射的方法,所述方法用于一种远程桌面系统,所述远程桌面系统包括客户机和服务器,所述客户机外接有物理设备,所述服务器包括虚拟设备;所述客户机上安装通用驱动和第三方驱动,所述客户机上存在的应用程序至少包括第一应用程序和第二应用程序;所述第一应用程序为所述远程桌面系统的客户端程序,所述第一应用程序用于通过所述通用驱动控制所述物理设备,并建立所述物理设备与所述虚拟设备的映射,所述第一应用程序识别到所述物理设备时,触发所述客户机加载所述通用驱动;所述第二应用程序用于通过所述第三方驱动控制所述物理设备,所述第二应用程序识别到所述物理设备时,触发所述客户机加载所述第三方驱动;
所述方法包括:
所述客户机获取所述物理设备的识别信息,所述识别信息包括用于描述所述物理设备的关键字段,所述关键字段用于所述客户机上存在的应用程序识别所述物理设备;
在所述第一应用程序根据所述识别信息识别到所述物理设备后,所述客户机将所述识别信息由第一状态修改为第二状态;其中,处于所述第一状态的所述识别信息中的关键字段能够被所述客户机上存在的应用程序读取,并用于识别所述物理设备;处于所述第一状态的关键字段与处于所述第二状态的关键字段的不相同,处于所述第二状态的所述识别信息中的关键字段无法
被所述客户机上存在的应用程序用于识别所述物理设备。
结合第一方面,在第一方面的第一种可能的实现方式中,所述将所述识别信息由第一状态修改为第二状态包括:
所述客户机对所述关键字段按位取反,并将包括了按位取反后的关键字段的识别信息作为处于所述第二状态的识别信息。
结合第一方面,或第一方面的第一种可能的实现方式,在第一方面的第二种可能的实现方式中,还包括:
在将所述识别信息由第一状态修改为第二状态之前,所述客户机根据所述服务器发送的请求信息,判断所述请求信息所指向的物理设备的设备独占事件是否触发;
若触发所述设备独占事件,则在所述客户机根据所述识别信息识别所述请求信息所指向的物理设备后,所述客户机将所述识别信息由第一状态修改为第二状态。
结合第一方面的第二种可能的实现方式,在第一方面的第三种可能的实现方式中,还包括:
在所述物理设备与所述虚拟设备的映射被断开时,检测所述物理设备是否记录在独占列表中,若是,则所述客户机将所述识别信息由所述第二状态修改为第一状态,其中,在所述客户机将所述识别信息由第一状态修改为第二状态之后,所述物理设备被所述客户机记录在所述独占列表中;
或者,在所述设备独占事件被取消时,检测所述物理设备是否记录在所述独占列表中,若是,则所述客户机将所述识别信息由所述第二状态修改为第一状态。
结合第一方面的第三种可能的实现方式,在第一方面的第四种可能的实现方式中,所述物理设备包括USB设备,所述请求信息为携带了附加信息
的USB重定向请求,所述附加信息表示所述USB设备的设备独占事件触发或不触发,所述方法还包括:
所述客户机通过所述客户端程序接收所述服务器发送的所述USB重定向请求,并将所述USB重定向请求传输至所述通用驱动;
当所述附加信息表示所述USB设备的设备独占事件触发时,所述客户机通过所述通用驱动将所述识别信息由第一状态修改为第二状态,并将所述物理设备记录在所述独占列表中;并通过所述通用驱动将USB重定向的处理结果向所述客户端程序传输;
当所述附加信息表示所述USB设备的设备独占事件不触发时,所述客户机通过所述通用驱动将USB重定向的处理结果向所述客户端程序传输。
第二方面,本发明的实施例提供一种建立设备映射的装置,所述装置用于一种远程桌面系统中的客户机,所述远程桌面系统包括所述客户机和服务器,所述客户机外接有物理设备,所述服务器包括虚拟设备;所述客户机上安装通用驱动和第三方驱动,所述客户机上存在的应用程序至少包括第一应用程序和第二应用程序;所述第一应用程序为所述远程桌面系统的客户端程序,所述第一应用程序用于通过所述通用驱动控制所述物理设备,并建立所述物理设备与所述虚拟设备的映射,所述第一应用程序识别到所述物理设备时,触发所述客户机加载所述通用驱动;所述第二应用程序用于通过所述第三方驱动控制所述物理设备,所述第二应用程序识别到所述物理设备时,触发所述客户机加载所述第三方驱动;
所述装置包括:
第一获取模块,用于获取所述物理设备的识别信息,所述识别信息包括用于描述所述物理设备的关键字段,所述关键字段用于所述客户机上存在的应用程序识别所述物理设备;
第一处理模块,用于在所述第一应用程序根据所述识别信息识别到所述
物理设备后,所述客户机将所述识别信息由第一状态修改为第二状态;其中,处于所述第一状态的所述识别信息中的关键字段能够被所述客户机上存在的应用程序读取,并用于识别所述物理设备;处于所述第一状态的关键字段与处于所述第二状态的关键字段的不相同,处于所述第二状态的所述识别信息中的关键字段无法被所述客户机上存在的应用程序用于识别所述物理设备。
结合第二方面,在第二方面的第一种可能的实现方式中,所述第一处理模块包括:
第一处理子模块,用于对所述关键字段按位取反,并将包括了按位取反后的关键字段的识别信息作为处于所述第二状态的识别信息。
结合第二方面,或第二方面的第一种可能的实现方式,在第二方面的第二种可能的实现方式中,还包括:
判断模块,用于在将所述识别信息由第一状态修改为第二状态之前,根据所述服务器发送的请求信息,判断所述请求信息所指向的物理设备的设备独占事件是否触发;
第二处理模块,用于若触发所述设备独占事件,则在所述客户机根据所述识别信息识别所述请求信息所指向的物理设备后,将所述识别信息由第一状态修改为第二状态。
结合第二方面的第二种可能的实现方式,在第二方面的第三种可能的实现方式中,还包括:
第三处理模块,用于在所述物理设备与所述虚拟设备的映射被断开时,检测所述物理设备是否记录在独占列表中,若是,则所述客户机将所述识别信息由所述第二状态修改为第一状态,其中,在所述客户机将所述识别信息由第一状态修改为第二状态之后,所述物理设备被所述客户机记录在所述独占列表中;
或者,在所述设备独占事件被取消时,检测所述物理设备是否记录在所述独占列表中,若是,则所述客户机将所述识别信息由所述第二状态修改为第一状态。
结合第二方面的第三种可能的实现方式,在第二方面的第四种可能的实现方式中,所述物理设备包括USB设备,所述请求信息为携带了附加信息的USB重定向请求,所述附加信息表示所述USB设备的设备独占事件触发或不触发,所述装置还包括:
第四处理模块,用于通过所述客户端程序接收所述服务器发送的所述USB重定向请求,并将所述USB重定向请求传输至所述通用驱动;
当所述附加信息表示所述USB设备的设备独占事件触发时,通过所述通用驱动将所述识别信息由第一状态修改为第二状态,并将所述物理设备记录在所述独占列表中;并通过所述通用驱动将USB重定向的处理结果向所述客户端程序传输;
当所述附加信息表示所述USB设备的设备独占事件不触发时,通过所述通用驱动将USB重定向的处理结果向所述客户端程序传输。
本发明实施例提供的一种建立设备映射的方法及装置,能够在客户机获取设备的识别信息,并根据识别信息识别到设备后,将识别信息由第一状态修改为第二状态,使客户机中基于用户态驱动开发的应用程序,即第二应用程序,无法识别到该物理设备,相比较于现有技术,本发明能够通过修改设备的识别信息的状态,避免物理设备的驱动管理混乱,使物理设备与虚拟设备的映射不被断开,保证远程虚拟桌面系统中的应用能够正常使用该物理设备而不被中断。
为了更清楚地说明本发明实施例中的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明
的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其它的附图。
图1为本现有技术的具体应用场景的示意图;
图2为本发明实施例提供的一种建立设备映射的方法的流程图;
图3为本发明实施例提供的另一种建立设备映射的方法的流程图;
图4为本发明实施例提供的另一种建立设备映射的方法的流程图;
图5、图6为本发明实施例提供的另一种建立设备映射的方法的流程图;
图7为本发明实施例提供的另一种建立设备映射的方法的流程图;
图7a为本发明实施例提供的一种建立设备映射的方法的具体数据交互流程图;
图8为本发明实施例提供的一种建立设备映射的装置的结构示意图;
图8a、图8b、图8c、图8d为本发明实施例提供的一种建立设备映射的装置的结构示意图;
图9为本发明实施例提供的一种客户机设备的结构示意图。
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其它实施例,都属于本发明保护的范围。
本发明实施例可以应用于一种远程桌面系统,所述远程桌面系统至少包括客户机和服务器,所述客户机外接有物理设备,所述服务器包括虚拟设备;所述客户机上安装通用驱动和第三方驱动,所述客户机上存在的应用程序至少包括第一应用程序和第二应用程序;所述第一应用程序为所述远程桌面系统的客户端程序,所述第一应用程序用于通过所述通用驱动控制所述物理设备,并建立所述物理设备与所述虚拟设备的映射,所述第一应用程序识别到所述物理设备时,触发所述客户机加载所述通用驱动;所述第二应用程序用
于通过所述第三方驱动控制所述物理设备,所述第二应用程序识别到所述物理设备时,触发所述客户机加载所述第三方驱动。例如:如图1所示,程序1是一种基于用户态驱动开发的应用程序,可以作为第二应用程序;USB客户端可以作为第一应用程序。
以图1为例,在物理USB设备重定向的过程中,USB客户端或USB服务端会向客户机发送请求,触发客户机利用USB通用驱动针对物理USB设备开启重定向,就会强制解绑物理USB设备在默认状态下绑定的USB设备驱动,再把自身的USB通用驱动绑定到物理USB设备上,从而USB客户端占用了物理USB设备,并将物理USB设备用于重定向。其中,USB服务端位于服务器,USB设备驱动和USB通用驱动工作在内核态,属于内核态驱动;而“基于用户态驱动开发的应用程序”会通过相关系统API,强制解绑定物理USB设备当前绑定的USB内核态驱动,比如USB通用驱动,然后直接与物理USB设备进行交互,从而抢占物理USB设备。
本发明实施例提供一种建立设备映射的方法,如图2所示,包括:
101、所述客户机获取所述物理设备的识别信息。
其中,所述识别信息包括用于描述所述物理设备的关键字段,所述关键字段用于所述客户机上存在的应用程序识别所述物理设备。在识别信息中所包括的关键字段可以是一种或是多种的组合,例如:在表一中记载的是MAC OS中几种关键字段的可能组合方式:
表一
需要说明的是,识别信息中的关键字段的组合方式并不限定,可以是依
据现有标准协议中制定的组合,也可以由技术人员根据具体的情况设定,比如:对于一些免驱动的USB设备,客户机的操作系统一般不会关注idVendor+idProduct字段,而会关注其它标识字段。客户机的操作系统将关键字段读取并存入内存,以及客户机中的应用程序如何读取内存中的关键字段的具体实现方式,可以参照现有技术手段实现。
在本实施例中,当客户机上插入设备,客户机中使用通用驱动的子系统监听到物理USB设备插入的事件通知时,由客户机获取插入客户机的物理USB设备的识别信息;或者,在客户机子系统运行起来之前,物理USB设备已经插入客户机,客户机通过自动的遍历查询,周期性获取物理USB设备的识别信息。
102、所述客户机中的所述第一应用程序根据所述识别信息识别到所述物理设备后,所述客户机将所述识别信息由第一状态修改为第二状态。
其中,处于所述第一状态的所述识别信息中的关键字段能够被所述客户机上存在的应用程序读取,并用于识别所述物理设备;处于所述第一状态的关键字段与处于所述第二状态的关键字段的不相同,处于所述第二状态的所述识别信息中的关键字段无法被所述客户机上存在的应用程序用于识别所述物理设备。
在本实施例中,当客户机根据所获取的识别信息识别到插入的设备后,由客户机将所获取的识别信息由第一状态修改为第二状态。需要说明的是,由于第一应用程序已根据修改前的识别信息识别到了物理设备,因此第一应用程序根据处于第二状态的识别信息能否识别到物理设备,可以不做限定。本发明实施例提供的一种建立设备映射的方法,能够在客户机获取设备的识别信息,并根据识别信息识别到设备后,将识别信息由第一状态修改为第二状态,使客户机中基于用户态驱动开发的应用程序,即第二应用程序,无法识别到该物理设备,相比较于现有技术,本发明能够通过修改设备的识别信息的状态,避免物理设备的驱动管理混乱,使物理设备与虚拟设备的映射不
被断开,保证远程虚拟桌面系统中的应用能够正常使用该物理设备而不被中断。
在本实施例中,所述识别信息包括所述物理设备的内核驱动中的关键字段,所述关键字段的默认状态为所述第一状态。因此,在如图2所示的实现方式的基础上,102可以实现为如图3所示的201:
201、所述客户机对所述关键字段按位取反,并将包括了按位取反后的关键字段的识别信息作为处于所述第二状态的识别信息。
其中,当客户机根据所获取的识别信息识别到插入的设备后,由具有正在运行通用驱动的子系统的客户机将识别信息中的关键字段按位取反,将包括了按位取反后的关键字段的识别信息作为处于第二状态的识别信息,并在执行完毕修改过程后,可以将该设备记录在独占列表中,以便在物理设备与虚拟设备的映射被断开时,或者在设备独占事件被取消时,将识别信息由第二状态修改为第一状态。其中,在客户机将识别信息由第一状态修改为第二状态之后,物理设备被客户机记录在独占列表中。
例如:当物理USB设备插入客户机时,具有正在运行通用驱动的子系统的客户机获取到物理USB设备的识别信息,根据识别信息识别到所插入的物理USB设备,并针对udev的物理USB设备描述descriptor结构体中用于匹配的关键字段进行按位取反的修改过程,具体修改内容如下:
udev->descriptor.idProduct=~udev->descriptor.idProduct;
udev->descriptor.idVendor=~udev->descriptor.idVendor;
udev->descriptor.bDeviceClass=~udev->descriptor.bDeviceClass;
udev->descriptor.bDeviceProtocol=~udev->descriptor.bDeviceProtocol;
udev->descriptor.bDeviceSubClass=~udev->descriptor.bDeviceSubClass;
udev->descriptor.bcdDevice=~udev->descriptor.bcdDevice。
需要说明的是,将识别信息由第一状态修改为第二状态的方式不仅限于按位取反,还可以包括其他的修改方式。例如:所述客户机通过常用的加密算法对所述关键字段进行加密计算,并得到与所述关键字段的长度一致的加
密后的字段,并将加密后的字段作为第二状态的识别信息。再例如:所述客户机通过字段移位的方法对所述关键字段进行向左移位或者向右移位,并得到与所述关键字段的长度一致的移位后的关键字段,并将包括了移位后的关键字段的识别信息作为第二状态的识别信息。比如:支持策略配置提供,PID(1,100)和VID(1,200),表示对于独占设备,把识别信息中idProduct(产品ID)=1的字段,以及idVendor(供应商ID)=1的字段,修改为idProduct=100,idVendor=200。其中,在识别信息中idProduct(产品ID)=1的字段,idVendor(供应商ID)=1的字段修改前为第一状态;当修改为idProduct=100,idVendor=200时为第二状态。
并且,客户机根据识别信息识别到需要采用独占方式映射的设备后,可以将处于第一状态的识别信息,以及采用独占方式映射的物理设备记录在独占列表中,以便在映射被断开时或者在设备独占事件被取消时,客户机将包括了关键字段的识别信息由第二状态修改为第一状态。
本发明实施例提供的一种建立设备映射的方法,能够在客户机获取设备的识别信息,并根据识别信息识别到设备后,将识别信息中的关键字段,通过按位取反的方式由第一状态修改为第二状态,使客户机中基于用户态驱动开发的应用程序,即第二应用程序,无法识别到该物理设备,相比较于现有技术,本发明能够通过修改识别信息中的关键字段,从而修改设备的识别信息的状态,避免物理设备的驱动管理混乱,使物理设备与虚拟设备的映射不被断开,保证远程虚拟桌面系统中的应用能够正常使用该物理设备而不被中断。
在本实施例中,在如图2或如图3所示的实现方式的基础上,还可以实现为如图4所示的实现方式:
301、在将识别信息由第一状态修改为第二状态之前,所述客户机根据所述服务器发送的请求信息,判断所述请求信息所指向的物理设备的设备独占事件是否触发。
例如:在客户机上插入3个物理USB设备,其中,物理USB设备1、物理USB设备2需要与虚拟设备建立映射,物理USB设备3不需要与虚拟设备建立映射,则获取到3个物理USB设备的信息后,通过客户端向服务端发送,服务端根据3个物理USB设备的信息,结合策略配置进行判断,确认物理USB设备1、物理USB设备2需要重定向,以及是否独占,物理USB设备3不需要重定向;根据每个物理USB设备的信息生成请求信息,并通过客户端转发给通用驱动。
其中,请求信息中至少包括是否重定向,以及是否独占方式进行重定向的指令。
在本实施例中,当客户机接收到服务器发送的请求信息后,根据服务端返回的请求信息,请求信息用于表示物理USB设备的处理方式,物理USB设备的处理方式至少包括了独占重定向、非独占重定向和不重定向,比如:请求信息记录了物理USB设备1的状态为独占重定向,物理USB设备2的状态为非独占重定向,以及物理USB设备3的状态为不重定向,当客户机接收到该请求信息后,根据请求信息判断物理USB设备1触发设备独占事件,物理USB设备2通过现有技术手段进行重定向,物理USB设备3不触发设备重定向事件。
302、若触发所述设备独占事件,则在所述客户机根据所述识别信息识别所述请求信息所指向的物理设备后,所述客户机将所述识别信息由第一状态修改为第二状态。
若未触发所述设备独占事件,则不作独占处理。
其中,不作独占处理可以实现为不进行物理设备的状态信息的修改,且不将物理设备加入独占列表。
例如:当客户机接收到服务器发送的请求信息后,根据请求信息判断物理USB设备1触发设备独占重定向事件,物理USB设备2触发非独占重定向事件,物理USB设备3不触发设备重定向事件,则在客户机根据识别信息识别
请求信息所指向的物理USB设备1后,将物理USB设备1的识别信息由第一状态修改为第二状态;物理USB设备2触发非独占重定向事件,物理USB设备3不触发设备重定向事件,则不进行物理设备的状态信息的修改,且不将物理设备加入独占列表。
在本实施例中,通常由加载了USB内核驱动的子系统先检测到物理USB设备插入客户机,并读取该物理USB设备的识别信息以及其他描述符信息,比如:设备描述符、接口描述符、配置描述符等,再向各监听器广播该物理USB设备插入客户机的插入事件通知,以便将物理USB设备的识别信息通知客户端或服务端,并询问是否需要映射该物理USB设备,客户端或服务端根据策略配置情况,返回请求信息,请求信息涉及是否需要重定向,以及如果重定向时,采用的重定向方式的指令。
需要说明的是,识别信息可以多次获取,即在获取请求信息之后,还可以根据需要再次获取识别信息。
本发明实施例提供的一种建立设备映射的方法,能够根据服务器发送的请求信息,判断针对请求信息所指向的物理设备触发独占事件,在客户机获取设备的识别信息,并根据识别信息识别到设备后,将识别信息由第一状态修改为第二状态,使客户机中基于用户态驱动开发的应用程序,即第二应用程序,无法识别到该物理设备,相比较于现有技术,本发明能够根据服务器发送的请求信息,判断针对请求信息所指向的物理设备触发独占事件,通过修改触发独占事件的设备的识别信息的状态,避免物理设备的驱动管理混乱,使物理设备与虚拟设备的映射不被断开,保证远程虚拟桌面系统中的应用能够正常使用该物理设备而不被中断。
在本实施例中,在所述物理设备与所述虚拟设备的映射被断开时,或者在所述设备独占事件被取消时,若所述物理设备记录在独占列表中,则所述客户机将所述识别信息由所述第二状态修改为第一状态,并将该物理设备从独占列表中删除。因此,在如图4所示的实现方式的基础上,还可以实现为
如图5所示,或如图6所示的实现方式:
401、在所述物理设备与所述虚拟设备的映射被断开时,检测所述物理设备是否记录在独占列表中。
或者,
402、在所述设备独占事件被取消时,检测所述物理设备是否记录在所述独占列表中。
403、若在所述物理设备与所述虚拟设备的映射被断开时,或者在所述设备独占事件被取消时,所述物理设备记录在独占列表中,则所述客户机将所述识别信息由所述第二状态修改为第一状态。
其中,在所述客户机将所述识别信息由第一状态修改为第二状态之后,所述物理设备被所述客户机记录在所述独占列表中。
在物理设备与虚拟设备的映射被断开时,或者在设备独占事件被取消时,检测该物理设备是否记录在独占列表中,若该物理设备已经记录在独占列表中,则客户机将识别信息,由第二状态修改为第一状态,并将该物理设备从独占列表中删除;若该物理设备未被记录在独占列表中,则不作处理。
本发明实施例提供的一种建立设备映射的方法,能够根据服务器发送的请求信息,判断针对请求信息所指向的物理设备触发独占事件,在客户机获取设备的识别信息,并根据识别信息识别到设备后,将识别信息由第一状态修改为第二状态,使客户机中基于用户态驱动开发的应用程序,即第二应用程序,无法识别到该物理设备,从而完成该物理设备与虚拟设备的映射;在物理设备与虚拟设备的映射被断开时,或者在设备独占事件被取消时,若物理设备记录在独占列表中,则客户机将识别信息由第二状态修改为第一状态,并将该物理设备从独占列表中删除。相比较于现有技术中,本发明的客户机将识别信息由第一状态修改为第二状态,且在物理设备与虚拟设备的映射被断开时,或者在设备独占事件被取消时,若物理设备记录在独占列表中,则客户机将识别信息由第二状态修改为第一状态,并将该物理设备从独占列
表中删除,避免物理设备的驱动管理混乱,使物理设备与虚拟设备的映射不被断开,保证远程虚拟桌面系统中的应用能够正常使用该物理设备而不被中断。
在本实施例中,所述物理设备包括USB设备,所述请求信息为携带了附加信息的USB重定向请求,所述附加信息表示所述USB设备的设备独占事件触发或不触发,因此,在如图5或图6所示的实现方式的基础上,还可以实现为如图7所示的实现方式:
501、所述客户机通过所述客户端程序接收所述服务器发送的所述USB重定向请求,并将所述USB重定向请求传输至所述通用驱动。
502、判断所述附加信息表示所述USB设备的设备独占事件是否触发。
503、当所述附加信息表示所述USB设备的设备独占事件触发时,所述客户机通过所述通用驱动将所述识别信息由第一状态修改为第二状态,并将所述物理设备记录在所述独占列表中;并通过所述通用驱动将USB重定向的处理结果向所述客户端程序传输。
504、当所述附加信息表示所述USB设备的设备独占事件不触发时,所述客户机通过所述通用驱动将USB重定向的处理结果向所述客户端程序传输。
在客户机上用于实现远程虚拟桌面系统的软件程序可以称为客户端,在服务器上用于实现远程虚拟桌面系统的软件程序可以称为服务端。在本实施例中,在重定向过程中,即在客户机根据所获取的插入设备的识别信息,建立客户机上所插入的USB设备与虚拟USB设备的映射的过程中,如图7a所示,具体的数据交互过程如下:
当正在运行通用驱动的子系统监听到,客户机上插入USB设备的事件通知时,在通用驱动已被打开的情况下,封装生成的相关数据,并通知客户端读取;
客户端向正在运行通用驱动的子系统读取封装数据,提取USB设备的
相关数据信息,并将新插入的USB设备的相关数据信息,通过虚拟通道向服务端发送;
服务端接收到USB设备的相关数据信息,结合当前配置的重定向策略及独占策略,判断新插入的USB设备是否允许映射;需要说明的,判断新插入的USB设备是否允许映射也可在客户端进行,本实施例对此不作具体限定。
如果允许映射,则服务端向客户端发送开启该USB设备重定向的通知,以及“是否独占”的信息,并由客户端把携带附加信息,以及服务端开启USB设备重定向的请求,转发给正在运行通用驱动的子系统处理,需要说明的是,当附加信息表示USB设备的设备独占事件触发时,客户机通过通用驱动将识别信息由第一状态修改为第二状态,并将物理设备记录在独占列表中,并通过通用驱动将USB重定向的处理结果向客户端程序传输;当附加信息表示USB设备的设备独占事件不触发时,客户机通过通用驱动将USB重定向的处理结果向客户端程序传输;
正在运行通用驱动的子系统接收到请求、附加信息,分别采用不同方式开启重定向,对USB设备进行驱动替换、认领接口,并通知客户端读取封装后的处理结果,开启USB设备的重定向;客户端向正在运行总线驱动的虚拟桌面系统读取封装后的处理结果,提取出响应结果,并将响应结果向服务端发送;
服务端分析接收到的响应结果,判断是否成功开启重定向,若成功开启,则向正在运行总线驱动的虚拟桌面系统发送创建虚拟USB设备的通知;
正在运行总线驱动的虚拟桌面系统根据服务端发送的请求,创建虚拟USB设备,之后服务器就会感知到新USB设备出现,并做出相应的处理。
本发明实施例提供的一种建立设备映射的方法,能够在客户机获取设备的识别信息,并根据识别信息识别到设备后,将识别信息由第一状态修改为第二状态,使客户机中基于用户态驱动开发的应用程序,即第二应用程序,
无法识别到该物理设备,相比较于现有技术,本发明能够通过修改设备的识别信息的状态,避免物理设备的驱动管理混乱,使物理设备与虚拟设备的映射不被断开,保证远程虚拟桌面系统中的应用能够正常使用该物理设备而不被中断。
本发明实施例提供一种建立设备映射的装置60,如图8所示,所述装置60用于一种远程桌面系统,所述远程桌面系统包括客户机和服务器,所述客户机外接有物理设备,所述服务器包括虚拟设备;所述客户机上安装通用驱动和第三方驱动,所述客户机上存在的应用程序至少包括第一应用程序和第二应用程序;所述第一应用程序为所述远程桌面系统的客户端程序,所述第一应用程序用于通过所述通用驱动控制所述物理设备,并建立所述物理设备与所述虚拟设备的映射,所述第一应用程序识别到所述物理设备时,触发所述客户机加载所述通用驱动;所述第二应用程序用于通过所述第三方驱动控制所述物理设备,所述第二应用程序识别到所述物理设备时,触发所述客户机加载所述第三方驱动;
所述装置60包括:
第一获取模块61,用于获取所述物理设备的识别信息,所述识别信息包括用于描述所述物理设备的关键字段,所述关键字段用于所述客户机上存在的应用程序识别所述物理设备。
第一处理模块62,用于在所述第一应用程序根据所述识别信息识别到所述物理设备后,所述客户机将所述识别信息由第一状态修改为第二状态;其中,处于所述第一状态的所述识别信息中的关键字段能够被所述客户机上存在的应用程序读取,并用于识别所述物理设备;处于所述第一状态的关键字段与处于所述第二状态的关键字段的不相同,处于所述第二状态的所述识别信息中的关键字段无法被所述客户机上存在的应用程序用于识别所述物理设备。
在本实施例中,如图8a所示,所述第一处理模块62包括:
第一处理子模块621,用于对所述关键字段按位取反,并将包括了按位取反后的关键字段的识别信息作为处于所述第二状态的识别信息。
在本实施例中,在如图8所示或如图8a所示的基础上,如图8b所示,所述装置60还包括:
判断模块63,用于在将所述识别信息由第一状态修改为第二状态之前,根据所述服务器发送的请求信息,判断所述请求信息所指向的物理设备的设备独占事件是否触发。
第二处理模块64,用于若触发所述设备独占事件,则在所述客户机根据所述识别信息识别所述请求信息所指向的物理设备后,将所述识别信息由第一状态修改为第二状态。
在本实施例中,在如图8b所示的基础上,如图8c所示,所述装置60还包括:
第三处理模块65,用于在所述物理设备与所述虚拟设备的映射被断开时,检测所述物理设备是否记录在独占列表中,若是,则所述客户机将所述识别信息由所述第二状态修改为第一状态,其中,在所述客户机将所述识别信息由第一状态修改为第二状态之后,所述物理设备被所述客户机记录在所述独占列表中;
或者,在所述设备独占事件被取消时,检测所述物理设备是否记录在所述独占列表中,若是,则所述客户机将所述识别信息由所述第二状态修改为第一状态。
在本实施例中,在如图8c所示的基础上,所述物理设备包括USB设备,所述请求信息为携带了附加信息的USB重定向请求,所述附加信息表示所述USB设备的设备独占事件触发或不触发,如图8d所示,所述装置60还包括:
第四处理模块66,用于通过所述客户端程序接收所述服务器发送的所述USB重定向请求,并将所述USB重定向请求传输至所述通用驱动;
当所述附加信息表示所述USB设备的设备独占事件触发时,通过所述通
用驱动将所述识别信息由第一状态修改为第二状态,并将所述物理设备记录在所述独占列表中;并通过所述通用驱动将USB重定向的处理结果向所述客户端程序传输;
当所述附加信息表示所述USB设备的设备独占事件不触发时,通过所述通用驱动将USB重定向的处理结果向所述客户端程序传输。
本发明实施例提供的一种建立设备映射的装置,能够在客户机获取设备的识别信息,并根据识别信息识别到设备后,将识别信息由第一状态修改为第二状态,使客户机中基于用户态驱动开发的应用程序,即第二应用程序,无法识别到该物理设备,相比较于现有技术,本发明能够通过修改设备的识别信息的状态,避免物理设备的驱动管理混乱,使物理设备与虚拟设备的映射不被断开,保证远程虚拟桌面系统中的应用能够正常使用该物理设备而不被中断。
本发明实施例提供了一种客户机设备70,如图9所示,至少包括:处理器701、网络接口702、存储器703和通信总线704;所述通信总线704用于实现所述处理器701、所述网络接口702和所述存储器703之间的连接通信;所述存储器703,用于存储所述客户机设备70在运行过程中所涉及的数据;可选的,还包含用户接口705,包括显示器,键盘或者点击设备(例如,鼠标,轨迹球(trackball),触感板或者触感显示屏)。存储器703可能包含高速RAM存储器,也可能还包括非不稳定的存储器(non-volatile memory),例如至少一个磁盘存储器。存储器703可选的可以包含至少一个位于远离前述处理器701的存储装置;其中,所述客户机设备70用于一种远程桌面系统,所述远程桌面系统包括客户机设备70和服务器,所述客户机设备70外接有物理设备,所述服务器包括虚拟设备;所述客户机设备70上安装通用驱动和第三方驱动,所述客户机设备70上存在的应用程序至少包括第一应用程序和第二应用程序;所述第一应用程序为所述远程桌面系统的客户端程序,所述第一应用程序用于通过所述通用驱动控制所述物理设备,并建立所述物理设备与所
述虚拟设备的映射,所述第一应用程序识别到所述物理设备时,触发所述客户机设备70加载所述通用驱动;所述第二应用程序用于通过所述第三方驱动控制所述物理设备,所述第二应用程序识别到所述物理设备时,触发所述客户机设备70加载所述第三方驱动。
在一些实施方式中,存储器703存储了如下的元素,可执行模块或者数据结构,或者他们的子集,或者他们的扩展集:
其中操作业务系统7031,包含各种业务系统程序,用于实现各种基础业务以及处理基于硬件的任务;应用程序7032,包含各种应用程序,用于实现各种应用业务。
在本实施例中,所述网络接口702,用于获取所述物理设备的识别信息,所述识别信息包括用于描述所述物理设备的关键字段,所述关键字段用于所述客户机设备70上存在的应用程序识别所述物理设备。
所述处理器701,用于在所述第一应用程序根据所述识别信息识别到所述物理设备后,所述客户机设备70将所述识别信息由第一状态修改为第二状态;其中,处于所述第一状态的所述识别信息中的关键字段能够被所述客户机设备70上存在的应用程序读取,并用于识别所述物理设备;处于所述第一状态的关键字段与处于所述第二状态的关键字段的不相同,处于所述第二状态的所述识别信息中的关键字段无法被所述客户机设备70上存在的应用程序用于识别所述物理设备。
在本实施例中,所述处理器701,具体用于对所述关键字段按位取反,并将包括了按位取反后的关键字段的识别信息作为处于所述第二状态的识别信息。
在本实施例中,所述处理器701,还用于在将所述识别信息由第一状态修改为第二状态之前,根据所述服务器发送的请求信息,判断所述请求信息所指向的物理设备的设备独占事件是否触发;
若触发所述设备独占事件,则在所述客户机设备70根据所述识别信息识
别所述请求信息所指向的物理设备后,将所述识别信息由第一状态修改为第二状态。
在本实施例中,所述处理器701,还用于在所述物理设备与所述虚拟设备的映射被断开时,检测所述物理设备是否记录在独占列表中,若是,则所述客户机设备70将所述识别信息由所述第二状态修改为第一状态,其中,在所述客户机设备70将所述识别信息由第一状态修改为第二状态之后,所述物理设备被所述客户机设备70记录在所述独占列表中;
或者,在所述设备独占事件被取消时,检测所述物理设备是否记录在所述独占列表中,若是,则所述客户机设备70将所述识别信息由所述第二状态修改为第一状态。
在本实施例中,所述物理设备包括USB设备,所述请求信息为携带了附加信息的USB重定向请求,所述附加信息表示所述USB设备的设备独占事件触发或不触发;所述处理器701,还用于通过所述客户端程序接收所述服务器发送的所述USB重定向请求,并将所述USB重定向请求传输至所述通用驱动;
当所述附加信息表示所述USB设备的设备独占事件触发时,通过所述通用驱动将所述识别信息由第一状态修改为第二状态,并将所述物理设备记录在所述独占列表中;并通过所述通用驱动将USB重定向的处理结果向所述客户端程序传输;
当所述附加信息表示所述USB设备的设备独占事件不触发时,通过所述通用驱动将USB重定向的处理结果向所述客户端程序传输。
本发明实施例提供的一种客户机设备,能够在客户机设备获取设备的识别信息,并根据识别信息识别到设备后,将识别信息由第一状态修改为第二状态,使客户机设备中基于用户态驱动开发的应用程序,即第二应用程序,无法识别到该物理设备,相比较于现有技术,本发明能够通过修改设备的识别信息的状态,避免物理设备的驱动管理混乱,使物理设备与虚拟设备的映
射不被断开,保证远程虚拟桌面系统中的应用能够正常使用该物理设备而不被中断。
本说明书中的各个实施例均采用递进的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于设备实施例而言,由于其基本相似于方法实施例,所以描述得比较简单,相关之处参见方法实施例的部分说明即可。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成,所述的程序可存储于计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。其中,所述的存储介质可为磁碟、光盘、只读存储记忆体(Read-Only Memory,ROM)或随机存储记忆体(Random Access Memory,RAM)等。
以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到的变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应该以权利要求的保护范围为准。
Claims (10)
- 一种建立设备映射的方法,其特征在于,所述方法用于一种远程桌面系统,所述远程桌面系统包括客户机和服务器,所述客户机外接有物理设备,所述服务器包括虚拟设备;所述客户机上安装通用驱动和第三方驱动,所述客户机上存在的应用程序至少包括第一应用程序和第二应用程序;所述第一应用程序为所述远程桌面系统的客户端程序,所述第一应用程序用于通过所述通用驱动控制所述物理设备,并建立所述物理设备与所述虚拟设备的映射,所述第一应用程序识别到所述物理设备时,触发所述客户机加载所述通用驱动;所述第二应用程序用于通过所述第三方驱动控制所述物理设备,所述第二应用程序识别到所述物理设备时,触发所述客户机加载所述第三方驱动;所述方法包括:所述客户机获取所述物理设备的识别信息,所述识别信息包括用于描述所述物理设备的关键字段,所述关键字段用于所述客户机上存在的应用程序识别所述物理设备;在所述第一应用程序根据所述识别信息识别到所述物理设备后,所述客户机将所述识别信息由第一状态修改为第二状态;其中,处于所述第一状态的所述识别信息中的关键字段能够被所述客户机上存在的应用程序读取,并用于识别所述物理设备;处于所述第一状态的关键字段与处于所述第二状态的关键字段的不相同,处于所述第二状态的所述识别信息中的关键字段无法被所述客户机上存在的应用程序用于识别所述物理设备。
- 根据权利要求1所述的建立设备映射的方法,其特征在于,所述将所述识别信息由第一状态修改为第二状态包括:所述客户机对所述关键字段按位取反,并将包括了按位取反后的关键字段的识别信息作为处于所述第二状态的识别信息。
- 根据权利要求1或2所述的建立设备映射的方法,其特征在于,还 包括:在将所述识别信息由第一状态修改为第二状态之前,所述客户机根据所述服务器发送的请求信息,判断所述请求信息所指向的物理设备的设备独占事件是否触发;若触发所述设备独占事件,则在所述客户机根据所述识别信息识别所述请求信息所指向的物理设备后,所述客户机将所述识别信息由第一状态修改为第二状态。
- 根据权利要求3所述的建立设备映射的方法,其特征在于,还包括:在所述物理设备与所述虚拟设备的映射被断开时,检测所述物理设备是否记录在独占列表中,若是,则所述客户机将所述识别信息由所述第二状态修改为第一状态,其中,在所述客户机将所述识别信息由第一状态修改为第二状态之后,所述物理设备被所述客户机记录在所述独占列表中;或者,在所述设备独占事件被取消时,检测所述物理设备是否记录在所述独占列表中,若是,则所述客户机将所述识别信息由所述第二状态修改为第一状态。
- 根据权利要求4所述的建立设备映射的方法,其特征在于,所述物理设备包括USB设备,所述请求信息为携带了附加信息的USB重定向请求,所述附加信息表示所述USB设备的设备独占事件触发或不触发,所述方法还包括:所述客户机通过所述客户端程序接收所述服务器发送的所述USB重定向请求,并将所述USB重定向请求传输至所述通用驱动;当所述附加信息表示所述USB设备的设备独占事件触发时,所述客户机通过所述通用驱动将所述识别信息由第一状态修改为第二状态,并将所述物理设备记录在所述独占列表中;并通过所述通用驱动将USB重定向的处理结果向所述客户端程序传输;当所述附加信息表示所述USB设备的设备独占事件不触发时,所述客 户机通过所述通用驱动将USB重定向的处理结果向所述客户端程序传输。
- 一种建立设备映射的装置,其特征在于,所述装置用于一种远程桌面系统中的客户机,所述远程桌面系统包括所述客户机和服务器,所述客户机外接有物理设备,所述服务器包括虚拟设备;所述客户机上安装通用驱动和第三方驱动,所述客户机上存在的应用程序至少包括第一应用程序和第二应用程序;所述第一应用程序为所述远程桌面系统的客户端程序,所述第一应用程序用于通过所述通用驱动控制所述物理设备,并建立所述物理设备与所述虚拟设备的映射,所述第一应用程序识别到所述物理设备时,触发所述客户机加载所述通用驱动;所述第二应用程序用于通过所述第三方驱动控制所述物理设备,所述第二应用程序识别到所述物理设备时,触发所述客户机加载所述第三方驱动;所述装置包括:第一获取模块,用于获取所述物理设备的识别信息,所述识别信息包括用于描述所述物理设备的关键字段,所述关键字段用于所述客户机上存在的应用程序识别所述物理设备;第一处理模块,用于在所述第一应用程序根据所述识别信息识别到所述物理设备后,所述客户机将所述识别信息由第一状态修改为第二状态;其中,处于所述第一状态的所述识别信息中的关键字段能够被所述客户机上存在的应用程序读取,并用于识别所述物理设备;处于所述第一状态的关键字段与处于所述第二状态的关键字段的不相同,处于所述第二状态的所述识别信息中的关键字段无法被所述客户机上存在的应用程序用于识别所述物理设备。
- 根据权利要求6所述的建立设备映射的装置,其特征在于,所述第一处理模块包括:第一处理子模块,用于对所述关键字段按位取反,并将包括了按位取反后的关键字段的识别信息作为处于所述第二状态的识别信息。
- 根据权利要求6或7所述的建立设备映射的装置,其特征在于,还包括:判断模块,用于在将所述识别信息由第一状态修改为第二状态之前,根据所述服务器发送的请求信息,判断所述请求信息所指向的物理设备的设备独占事件是否触发;第二处理模块,用于若触发所述设备独占事件,则在所述客户机根据所述识别信息识别所述请求信息所指向的物理设备后,将所述识别信息由第一状态修改为第二状态。
- 根据权利要求8所述的建立设备映射的装置,其特征在于,还包括:第三处理模块,用于在所述物理设备与所述虚拟设备的映射被断开时,检测所述物理设备是否记录在独占列表中,若是,则所述客户机将所述识别信息由所述第二状态修改为第一状态,其中,在所述客户机将所述识别信息由第一状态修改为第二状态之后,所述物理设备被所述客户机记录在所述独占列表中;或者,在所述设备独占事件被取消时,检测所述物理设备是否记录在所述独占列表中,若是,则所述客户机将所述识别信息由所述第二状态修改为第一状态。
- 根据权利要求9所述的建立设备映射的装置,其特征在于,所述物理设备包括USB设备,所述请求信息为携带了附加信息的USB重定向请求,所述附加信息表示所述USB设备的设备独占事件触发或不触发,所述装置还包括:第四处理模块,用于通过所述客户端程序接收所述服务器发送的所述USB重定向请求,并将所述USB重定向请求传输至所述通用驱动;当所述附加信息表示所述USB设备的设备独占事件触发时,通过所述通用驱动将所述识别信息由第一状态修改为第二状态,并将所述物理设备记录在所述独占列表中;并通过所述通用驱动将USB重定向的处理结果向 所述客户端程序传输;当所述附加信息表示所述USB设备的设备独占事件不触发时,通过所述通用驱动将USB重定向的处理结果向所述客户端程序传输。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201410683064.6A CN104484291B (zh) | 2014-11-24 | 2014-11-24 | 一种建立设备映射的方法及装置 |
CN201410683064.6 | 2014-11-24 |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2016082549A1 true WO2016082549A1 (zh) | 2016-06-02 |
Family
ID=52758834
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/CN2015/083283 WO2016082549A1 (zh) | 2014-11-24 | 2015-07-03 | 一种建立设备映射的方法及装置 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN104484291B (zh) |
WO (1) | WO2016082549A1 (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112099642A (zh) * | 2020-08-18 | 2020-12-18 | 西安万像电子科技有限公司 | 一种hid类设备的远端映射方法及设备 |
Families Citing this family (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104484291B (zh) * | 2014-11-24 | 2017-08-25 | 华为技术有限公司 | 一种建立设备映射的方法及装置 |
CN105183674B (zh) * | 2015-08-26 | 2019-01-08 | 深信服科技股份有限公司 | Usb虚拟化网络映射方法、装置以及usb集线器 |
CN105183675B (zh) * | 2015-09-30 | 2018-03-27 | 华为技术有限公司 | 对usb设备的访问方法、装置、终端、服务器及系统 |
CN105653028B (zh) * | 2015-12-25 | 2019-02-19 | 福建升腾资讯有限公司 | 一种基于远程桌面协议对人体工程学设备进行usb映射的方法 |
CN108984265B (zh) * | 2018-05-24 | 2020-12-15 | 深圳市腾讯网络信息技术有限公司 | 检测虚拟机环境的方法及装置 |
CN114090475A (zh) * | 2020-07-02 | 2022-02-25 | 中兴通讯股份有限公司 | Usb设备重定向方法、系统、电子设备及存储介质 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101035039A (zh) * | 2007-04-20 | 2007-09-12 | 福建升腾资讯有限公司 | Usb映射方法 |
CN102270186A (zh) * | 2011-07-21 | 2011-12-07 | 华中科技大学 | 一种虚拟桌面外部设备支持系统 |
CN102281264A (zh) * | 2010-06-13 | 2011-12-14 | 杭州华三通信技术有限公司 | 实现usb主机远程访问的虚拟usb系统和设备及方法 |
CN103823771A (zh) * | 2014-03-04 | 2014-05-28 | 飞天诚信科技股份有限公司 | 一种远程通信方法和系统 |
CN104484291A (zh) * | 2014-11-24 | 2015-04-01 | 华为技术有限公司 | 一种建立设备映射的方法及装置 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7890669B2 (en) * | 2005-11-25 | 2011-02-15 | Hitachi, Ltd. | Computer system for sharing I/O device |
-
2014
- 2014-11-24 CN CN201410683064.6A patent/CN104484291B/zh active Active
-
2015
- 2015-07-03 WO PCT/CN2015/083283 patent/WO2016082549A1/zh active Application Filing
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101035039A (zh) * | 2007-04-20 | 2007-09-12 | 福建升腾资讯有限公司 | Usb映射方法 |
CN102281264A (zh) * | 2010-06-13 | 2011-12-14 | 杭州华三通信技术有限公司 | 实现usb主机远程访问的虚拟usb系统和设备及方法 |
CN102270186A (zh) * | 2011-07-21 | 2011-12-07 | 华中科技大学 | 一种虚拟桌面外部设备支持系统 |
CN103823771A (zh) * | 2014-03-04 | 2014-05-28 | 飞天诚信科技股份有限公司 | 一种远程通信方法和系统 |
CN104484291A (zh) * | 2014-11-24 | 2015-04-01 | 华为技术有限公司 | 一种建立设备映射的方法及装置 |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112099642A (zh) * | 2020-08-18 | 2020-12-18 | 西安万像电子科技有限公司 | 一种hid类设备的远端映射方法及设备 |
Also Published As
Publication number | Publication date |
---|---|
CN104484291B (zh) | 2017-08-25 |
CN104484291A (zh) | 2015-04-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
WO2016082549A1 (zh) | 一种建立设备映射的方法及装置 | |
US10623431B2 (en) | Discerning psychological state from correlated user behavior and contextual information | |
US10148694B1 (en) | Preventing data loss over network channels by dynamically monitoring file system operations of a process | |
US10192074B2 (en) | Technique for data loss prevention through clipboard operations | |
US9628374B1 (en) | Ethernet link aggregation with shared physical ports | |
US20150058823A1 (en) | Remote debugging in a cloud computing environment | |
WO2016101288A1 (zh) | 一种远程直接数据存取方法、设备和系统 | |
US10182126B2 (en) | Multilevel redirection in a virtual desktop infrastructure environment | |
US20160019104A1 (en) | Cross-domain data sharing with permission control | |
US10929537B2 (en) | Systems and methods of protecting data from malware processes | |
US9633199B2 (en) | Using a declaration of security requirements to determine whether to permit application operations | |
JP6096376B2 (ja) | アクセス制御方法、装置、プログラム、及び記録媒体 | |
CN105069383A (zh) | 一种云桌面usb存储外设管控的方法及系统 | |
US10691310B2 (en) | Copying/pasting items in a virtual desktop infrastructure (VDI) environment | |
JP2018525713A (ja) | 極秘チャットデータの保護 | |
US10489311B1 (en) | Managing webUSB support for local and redirected USB devices | |
EP4172818B1 (en) | Shared resource identification | |
US10114779B2 (en) | Isolating a redirected USB device to a set of applications | |
US10628591B2 (en) | Method for fast and efficient discovery of data assets | |
EP2987093B1 (en) | Website server request rerouting | |
US10146499B2 (en) | System and method to redirect display-port audio playback devices in a remote desktop protocol session | |
US10261921B2 (en) | Universal secure platform virtualization system and method thereof | |
US20180321970A1 (en) | Controlling Background Activity of an Application Using a Policy | |
KR20150115238A (ko) | 클라우드 컴퓨팅 방법, 이를 수행하는 클라우드 컴퓨팅 서버 및 이를 저장하는 기록매체 | |
JP6459637B2 (ja) | 情報処理装置、情報処理方法及びプログラム |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 15864275 Country of ref document: EP Kind code of ref document: A1 |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
122 | Ep: pct application non-entry in european phase |
Ref document number: 15864275 Country of ref document: EP Kind code of ref document: A1 |