Arhn - архитектура программирования

как экранировать специальные символы пароля mariadb в сценарии оболочки

Мне нужно написать сценарий оболочки для входа в mariadb. Сценарий оболочки считывает один пароль, содержащий специальные символы (пробел, !@) в файле ini.

ОС — Ubuntu 18.04.

ini-файл следующим образом:

user=xxx-xxx-xxx
password=xxx /xxx /xx/ !\@

сценарий оболочки следующим образом:

#!/bin/bash
baseDir="$(cd "$(dirname "$0")" && pwd)"
iniPath="$baseDir/backup.ini"
echo "iniPath is $iniPath"

dbUser="$(grep 'user' $iniPath | cut -d '=' -f 2)"
echo "user is $dbUser"

dbPassword="$(grep 'password' $iniPath | cut -d '=' -f 2)"
echo "password is $dbPassword"

mysql -h localhost -u $dbUser -p'$dbPassword' 

если я ввожу команду следующим образом: mysql -h localhost -u xxxxxx -p'xxx /xxx /xx/ !@' в командной строке, она успешно регистрируется. Но если я выполняю сценарий оболочки, это всегда приводит к отказу в доступе для пользователя.

Есть предложения? Спасибо.

21.01.2019

  • Вы пытались использовать: mysql -h localhost -u $dbUser -p'`echo $dbPassword`' ? (специальный символ ` находится в США, как и на клавиатуре, под клавишей esc в левом верхнем углу, он выглядит как обратный апостроф) Похоже, что переменная с паролем неправильно печатается в команде mysql перед ее запуском. Другой способ, которым я бы порекомендовал попробовать, - использовать -p$dbPassword 21.01.2019
  • Он отлично работает с -p$dbPassword. Спасибо, Хонза П. 22.02.2019
  • Круто, я написал это как ответ для всех, у кого есть похожая проблема. 26.02.2019

Ответы:


1

Вы пытались использовать: mysql -h localhost -u $dbUser -p'echo $dbPassword' ? (специальный символ ` находится в США, как и на клавиатуре, под клавишей esc в левом верхнем углу, он выглядит как обратный апостроф) Похоже, что переменная с паролем неправильно «печатается» в команде mysql перед ее запуском. Другой способ, которым я бы порекомендовал попробовать, - это использовать -p"$dbPassword"

26.02.2019
Новые материалы

Коллекции публикаций по глубокому обучению
Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

Представляем: Pepita
Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

Советы по коду Laravel #2
1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

3 способа решить квадратное уравнение (3-й мой любимый) -
1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

Создание VR-миров с A-Frame
Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

Демистификация рекурсии
КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..