Буфер обмена в RDP сессии удобно использовать для передачи текста и файлом между локальным компьютером и удаленным хостом (это может быть как рабочая станция Windows, так и RDS ферма на Windows Server). Иногда случается, что буфер обмена в терминальной сессии Windows (или приложении RemoteApp) перестает работать, и вы не можете передать (скопировать/вставить) ваши данные между вашим компьютером и RDP сервером.
Возможны несколько сценариев: проверьте, разрешено ли перенаправление буфера обмена на клиенте RDP, проверьте настройки копирования файлов/данных через буфер обмена RDP на сервере, перезапустите сбойный процесса rdpclip.exe в текущей терминальной сессии пользователя.
Перезапуск процесса буфера обмена в RDP сессии (rdpclip.exe)
Если буфер обмена в конкретной RDP сессии неожиданно перестал работать, а пункт Paste в контекстном меню удаленного компьютера стал неактивным, проще всего корректно завершить текущую RDP сессию (
logoff
) и подключиться заново. Это наверняка исправит проблему с буфером обмена. Но этом неудобно, потому что вам придется заново запускать все приложения в терминальном сеансе. Вы можете попробовать восстановить работу буфера обмена в RDP сессии без выполнения logoff.
ЗЗа работу буфера обмена между вашим компьютером и RDP хостом отвечает приложение rdpclip.exe. Для каждого удаленного пользователя при подключении к Remote Desktop стартует собственный процесс
rdpclip.exe
. С помощью Task Manager вы можете завершить процесс rdpclip.exe (RDP Clipboard Monitor/ Монитор буфера обмена RDP -> Emd task) и запустить его вручную (Task Manager -> File -> Start new task -> rdpclip.exe —> Enter).
Это обычно помогает быстро восстановить работу удаленного буфера обмена. Проверьте, работает ли теперь copy/paste (Ctrl+C / Ctrl+V) в RDP окне.
(Get-WmiObject -Query "select * from Win32_Process where name='RDPClip.exe'"|?{$_.GetOwner().User -eq $ENV:USERNAME}).Terminate()
rdpclip.exe
Для удобства можно подписать этот PowerShell скрипт или настроить политику PowerShell Execution Policy.
Разрешить буфера обмена в RDP клиенте Windows
Проверьте, что настройки вашего RDP клиента разрешают использовать буфер обмена в окне терминальной сессии.
Если вы используете встроенный RDP клиент Windows (Remote Desktop Connection, mstsc.exe) для подключения к удаленному терминальному серверу, проверьте что в его настройках разрешено копирования через RDP буфер обмена
Перейдите на вкладку Local Resources, проверьте что в секции “Choose the devices and resources that you want to use in your remote session” включена опция Clipboard (Буфер обмена).
Если вы хотите разрешить копировать файлы через буфер обмена RDP, нужно нажать кнопку More и включить опцию Drives. Это разрешит использовать локальные диски в RDP сессии для копирования файлов.
Если вы используете готовый *.RDP файл с настройками для подключения к удаленному компьютеру (например для подключения к RemoteApp), проверьте что в нем включены следующие опции:
redirectclipboard:i:1 redirectdrives:i:1 drivestoredirect:s:*
- redirectclipboard — разрешает использовать локальный буфер обмена в удаленной сессии;
- Drivestoredirect и redirectdrives – включают перенаправление в RDP сеанс для всех локальных дисков (нужна, если вы копируете файлы через RDP).
Как запретить/разрешить копирование через буфер обмена RDP в Windows?
С помощью параметров групповых политик или реестра вы можете разрешить или запретить использование RDP буфера обмена на хосте Windows для операций копировать/вставить.
- Запустите локальный редактор групповых политик–
gpedit.msc
; - Перейдите в секцию GPO Computer Configuration -> Administrative Templates -> Windows Components -> Remote Desktop Services -> Remote Desktop Session Host -> Device and Resource Redirection;
- Чтобы запретить копировать данные с/на удаленный сервер через буфер обмена RDP сессии установите Enabled для следующих политик:
Do not allow Clipboard redirection - Clipboard redirection используется для копирования текста и файлов через буфер обмена в RDP). Do not allow drive redirection - Drive mapping/redirection –позволяет пользователю получать доступ к своим локальным дискам в RDP сессии. Используется в том числе при копировании файлов.
При включении этих политик в ветке реестра HKEY_LOCAL_MACHINE\SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services будут созданы следующие DWORD параметры:
fDisableCdm = 1
(запретить подключение локальных дисков на RDP хосте)
fDisableClip = 1
(запретить передачу данных через буфер обмена между RDP сервером и клиентом)Аналогичные политики есть в пользовательском разделе GPO. Это значит, что вы можете отключить буфер обмен и подключаемые диски только для определенных пользователей RDP хоста. На отдельно-стоящем компьютере для отключения буфера обмена RDP для не-администраторов, можно использовать MLGPO. - Если вы хотите принудительно разрешить использование RDP буфера обмена, измените значения параметров на Disabled (по умолчанию использование RDPClip для обмена данными между локальным компьютером и удаленным RDP хостов разрешено);
- Обновите настройки политик командой
gpupdate /force
. Для применения новых настроек к пользователям, они должны завершить свои RDP сессии (через logoff, а не disconnect).
Вы можете полностью отключить RDP буфер и перенаправление локальных дисков для всех пользователей Windows хоста с включенным RDP доступом через реестр.
Для этого создайте REG_DWORD параметры в ветке реестра HKEY_LOCAL_MACHINE\Software\Microsoft\Terminal Server:
- DisableClipboardRedirection = 1
- DisableDriveRedirection = 1
И два параметра рассмотренных выше в ветке HKEY_LOCAL_MACHINE\SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services:
- fDisableCdm =1
- fDisableClip = 1
Чтобы быстро запретить копирование данных между компьютером и удаленным RDP хостом, выполните команды:
reg add "HKEY_LOCAL_MACHINE\Software\Microsoft\Terminal Server” /v “DisableClipboardRedirection" /t REG_DWORD /d 1 /f
reg add "HKEY_LOCAL_MACHINE\Software\Microsoft\Terminal Server” /v “DisableDriveRedirection" / t REG_DWORD /d 1 /f
reg add "HKEY_LOCAL_MACHINE\SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services" /v fDisableCdm /t REG_DWORD /d 1 /f
reg add "HKEY_LOCAL_MACHINE\SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services" /v fDisableClip /t REG_DWORD /d 1 /f
Если вы хотите, наоборот разрешить использовать буфер обмена RDP, эти параметры реестра должны отсутствовать (по умолчанию) или их значения должны быть равны 0.
Можно проверить значение параметром реестра с помощью PowerShell:
Get-ItemProperty -Path 'HKLM:SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services' | Select fDisableClip,fDisableCdm
Если у вас используются RDS сервера на Windows Server 2022,2019,2016, можно включить/отключить буфер обмена и локальные диски в настройках RDS коллекции. Откройте Server Manager -> Remote Desktop Services -> Collections -> Tasks -> Edit Properties -> Client Settings. Снимите галки у опций “Clipboard” и “Drive” в секции Enable redirecting for the following.
Параметр Drives позволяет использовать копирование файлов через буфер обмена (используются локальные диски в RDS сеансе).
Можно изменить настройки RDS коллекции с помощью PowerShell:
Set-RDSessionCollectionConfiguration -CollectionName myCol1 -ClientDeviceRedirectionOptions “Clipboard,Drive”
xcopy \\tsclient\c\distr\my.iso c:\serverfolder
Если у вас используется хост RDGateway для подключения к RDS, нужно учитывать что вы можете запретить или разрешить использовать буфер обмена в настройках вашей политики CAP (Connection Authorization Policy). По умолчанию в разделе Device Redirection включена опция Enable device redirection for all client devices. Здесь вы можете запретить перенаправление локального буфера обмена и дисков.
Если вы хотите запретить копировать из терминальной RDP сессии только для пользователей, но не для администраторов, можно изменить NTFS разрешения на файл
c:\windows\system32\rdpclip.exe
. Необходимо в свойствах файл убрать разрешение Read/Execute для встроенной группы Users (придется сначала изменить владельца файла с TrustedInstaller).
установил win 2008 r2 sp1 rus
включил сервер печати. но огда пользователи по терминалке на него заходят, то их принтеры с ними не переходят в сессию. не подскажете в чем может быть дело?
Воспользуйтесь возможностями Easy Print , или установите на сервер такие-же драйвера печати, которые стоят на клиенте. Первый вариант проще — главное, чтобы клиенты удовлетворяли требованиям, описанным в статье
Спасибо, разобрался. оказывается выбирал галочки «принтера, диски, буфер обмена…» думал, что написано, чтобы за собой брали, а там надо было дочитать «чтобы отключались эти функции»
Спасибо! Тоже самое начало происходить 2 недели назад, помогает перезагрузка сервера. Хватило на неделю, эта канитель начала происходить снова.
Остановка и запуск процесса rdpclip.exe помогает, но через раз. Когда после первого раза — все становится ок, а когда надо 10 раз его кильнуть.
сделал батник
TASKKILL /F /IM rdpclip.exe
rdpclip.exe
чтоб пользователи сами убивали и запускали процесс, помогает так же, через раз. Порой раз 20 надо запустить. А то и не помогает совсем.
И да, наблюдается только у тех у кого рабочая система XP, кто в 7ках работают — у тех нету проблемы с copy/paste.
Вы как нибудь победили эту проблему в итоге?
Alex Подобная проблема возникает нечасто, так что какого-то дополнительного траблшутинга и не проводилось. Хватало и перезапуска rdpclip.exe.
Как вариант, попробуйте обновить версию rdp клиента на клиентах с XP до последней доступной. Если удастся найти причину, будьте добры, поделитесь.
Проблема не только на ХР. Два клиента на 7ке жалуются на пропадающий буфер обмена (они много его используют), при этом те, кто мало копирует о проблеме вообще не знают.
На портале майкрософт в качестве решения лежат ветки реестра, для проверки. Все проверил — все ок, но проблема не уходит — что делать?
itpro — похоже на то что обновление прокатило, была версия 6.1, сейчас у проблемных 7я.
Вот с 24 по сегодня, как говорится, не было ни единого разрыва 🙂
Спасибо!
Nikin Подскажите, а что за решение с реестром вам удалось найти?
AlexПожалуйста 🙂
ссылку не хочет добавлять
«http://social.technet.microsoft.com/Forums/en-GB/winserverTS/thread/d92ad1c3-826f-496b-8145-bb31615c55fe»
никак не хочет добавлять ссылку. 🙁
Yuan Wang Microsoft China-PSG
Hi,
Please check your client PC and Terminal Server Registry Keys and Values.
You can open RUN, and type “regedit” to open the Registry Ediror.
Is the fDisableClip set to 0 under
HKLM\SYSTEM\CurrentControlSet\Control\Terminal Server\Winstations\RDP-Tcp ?
If fDisableClip is set to 1 rdpclip.exe will terminate, because clipboard mapping is disabled. Check that rdpclip is still listed under Addins
HKLM\SYSTEM\CurrentControlSet\Control\Terminal Server\Addins\Clip Redirector
Name REG_SZ RDPClip
Type REG_DWORD 0x00000003
______________________________
Sumesh P — Microsoft Online Community Support
Please check the following:
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Terminal Server\WinStations\RDP-Tcp
REG WORD: fDisableClip is set to 0
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Terminal Server\Wds\RDPWD
REG WORD: fDisableClip is set to 0
Verify that the following registry values are set to «rdpclip»
Key: HKLM\SYSTEM\CurrentControlSet\Control\Terminal Server\AddIns\Clip Redirector
Value: Name
Type: REG_SZ
Data: rdpclip
Key: HKLM\SYSTEM\CurrentControlSet\Control\Terminal Server\Wds\rdpwd
Value: StartupPrograms
Type: REG_SZ
Data: rdpclip
Make sure the policy is not enabled:
Computer Configuration —> Admin templates —> Windows Components —> Terminal Services—Terminal server -Device and Resource redirection —> «Do not allow clipboard redirection»
Let us know if that helps.
_________________________________
лучший ответ:
EFabian (Partner)
there was no entry like this:
Key: HKLM\SYSTEM\CurrentControlSet\Control\Terminal Server\Wds\rdpwd
Value: StartupPrograms
Type: REG_SZ
Data: rdpclip
so I created one and now it is working.
Thanks!!!
Nikin По ссылке на технет описана проблема, когда rdpclip совсем не стартовал на сервере, в вашем же случае он почему-то иногда отваливается.. можно конечно посидеть помониторить процесс rdpclip.exe на терминале, либо сделать задание планировщика, которое раз в 5 минут проверяет наличие процесса, и если он не запущен — запускает его. Костыли, конечно, но других идей нет (или обращайтесь в поддержку MS)
трудность в том, что он «не полностью» отваливается. Т.е. копирование происходит, но не с 1-го раза, а с х0-го…
Если на пк клиента стоит нод32 то ищи причину в этом. для чистоты эксперимена выруби нод и переконнектись в терминале. у меня сработало. как настроить нод для того чтобы не блокировал буфер искать не стал — купил каспер и забил.
кто знает как настроить нод — напишите, на все пк не хочется каспер покупать, только что лицензию нод продлил.
спасибо!!!!! Достаточно было просто снять указанный процесс и всё заработало!!!
Запилите батник:
cls
taskkill /F /FI «USERNAME eq %USERNAME%» /IM rdpclip.exe
ping -n 1 -w 1000 1.1.1.1>nul
start rdpclip.exe
Мне помогает всегда с первого раза. Локальная тачка: Win 7 x86, терминал: Server 2003, 2008
Егор, имеешь в виду что этот батник нужно иметь прямо на рабочем столе терминального сервер ?
Спасибо большое!!!!
Полезная статья!!!
Большое спасибо!!!думал уже сервак выкидывать в окно, значит еще рановато 🙂
Спасибо!
Вот огромное спасибище автору!!
Спасибо, бро! Убийство rdpclip помогло.
Пользователь может пристрелить собственный процесс rdpclip.exe с помощью такого PowerShell скрипта:
(Get-WmiObject -Query "select * from Win32_Process where name='RDPClip.exe'"|?{$_.GetOwner().User -eq $ENV:USERNAME}).Terminate()
rdpclip.exe
Просто разместите ярлык на рабочем столе пользователя.
Не знаю с чем связано, но столкнулся с этой траблой на древнем серваке win2003, все перепробовал, разве только новый транспорт не делал, но не работает буфер и все, пробросы принтеов дисков вся эта мелоч без проблем, даже звук и тот срабатывает. А буфер ни в какую. Надо еще рестартануть сервре попробовать. А вот почему отваливается кто нибудь нашел, или это из тех проблем которые не лечатся у мелкомягки, и только прикручивать очередной костыль?
Здравствуйте!
Сервер win2012r2,
клиент win10.
В параметрах коллекции разрешен буфер обмена, остальное отключено.
Текст копируется, файлы нет, в чем может быть проблема?
Попробуйте разрешить подключать диски в rdp сессию. По моему для копирования файлов нужен доступ к диску.
+
Похожая проблема, добавление доступа к диску (в свойствах коллекции )вроде помогло
Но не очень хочется юзверям давать доступ и прямо к локальному диску тоже…
Вот спасибо за совет! Всю голову изогнул, реестр и политики курочил! А так просто было… Помогло)))
Добрый день, подскажите, как сделать (если возможно), чтобы буфер обмена только текст копипастил, а файлы нет?
Не было такой задачи, не знаю можно ли так сделать.
Но я бы попробовал включить политики Do not allow drive redirection, возможно ее будет достаточно чтобы запретить копирование файлов, но оставить буфер обмена
Была проблема: на одном пользователе работало ок, на втором не работало (галочка в обоих стоит). Перезапустил процесс и все пошло. Спасибо.